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INTRODUCTION 

The recent entry of the single board computer into 

the broad field of electronic applications is sub- 
stantiating the billing as a "super component". 

Single board computers provide a solution to 

several problems that have not been solved by the 

use of conventional computers: cost, size, and 

design specialization. 

Many potential microcomputer applications have 
been overlooked because of the design tasks 
required to build a microcomputer system. These 
tasks traditionally include interfacing of the system 
clock, read/write memory, I/O ports and drivers, 
serial communications interface, bus control logic 
and drivers. Intel's SBC 80/10 enables the design 
engineer to concentrate on the application of 
microcomputers, rather than on implementation 
details. 

This application note begins with an overview of 
the Intel® SBC 80/10. Readers who are familiar 
with the SBC 80/10 may choose to skip to the 
applications section, which describes the following 
typical SBC 80/10 applications: 

• The SBC 80/10 used for instrumentation 
control of a Fluke 8375 Digital Multiineter. 

• The SBC 80/10 used as a SCADA Terminal 
in a communication applicaton. 

• The SBC 80/10 used for temperature moni- 
toring in a process control application. 

• The SBC 80/10 used as an interrupt driven 
device controller for a Centronics printer. 



Each example shows the user program and hard- 
ware required for the apphcation. The program 

hstings are interspersed with the text describing 
the application. Both 8080 Macro Assembly 
Language and Intel's PL/M-80 are used in the 
examples. 

The software was developed on an Intel® Micro- 
computer Development System (MDS). The MDS 
provided the tools necessary to edit, assemble or 
compile, link and locate the application software. 
Hardware development was facilitated by the use 
of Intel's In-Circuit Emulator (ICE 80). For further 
information regarding the Microcomputer Develop- 
ment System, the reader is referred to the publica- 
tions listed at the beginning of this application 
note. 

OVERVIEW 

The SBC 80/10 is a member of Intel's complete 
line of OEM computer systems which take full 
advantage of Intel's LSI technology to provide 
economical, self-contained computer based solu- 
tions for OEM applications. The SBC 80/10 is a 
complete computer system on a single 6.75-by-12 
inch printed circuit card. A block diagram of the 
SBC 80/10 is shown in Figure 1 . 

Intel's powerful 8-bit n-channel MOS 8080A CPU, 
fabricated on a single LSI chip, is the central 
processor for the SBC 80/10. The 8080A contains 
six 8-bit general purpose registers and an accumu- 
lator. The six general purpose registers may be 
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1. interrupts originating from the Programmable Communications Interface and Programmable Peripheral interface are jumper selectable. 



Figure 1. SBC 80110 Block Diasram 



addressed individually or in pairs, providing both 
single and double precision operators. 

The 8080 A has a 16-bit program counter which 
allows direct addressing of up to 64K bytes of 
memory. An external stack, located within any 
portion of read/write memory, may be used as a 
last in/first out stack to store the contents of the 
program counter, flags, accumulator and all of the 
six general purpose registers. A 16-bit stack pointer 
addresses the external stack. This provides sub- 
routine nesting that is bounded only by memory 
size. 

The SBC 80/10 contains IK bytes of read/write 
memory using Intel's low power static RAM. All 
on-board RAM read and write operations are per- 
formed at maximum processor speed. Sockets for 
up to 4K bytes of non-volatile read-only memory 
are provided on the board. Read-only memory may 
be added in IK byte increments using InteF 8708 
erasable and electrically reprogrammable ROMs 

(EPROMs) or Intel^ 8308 masked ROMs. All on- 
board ROM read operations are performed at 

maximum processor speed. 

The SBC 80/10 contains 48 programmable parallel 
I/O lines implemented using two Intel^ 8255 Pro- 
grammable Peripheral Interfaces. The system soft- 
ware is used to configure the I/O lines in any com- 
bination of unidirectional input/output, and 
bidirectional ports indicated in Table I. Therefore, 
the I/O interface may be customized to meet 
specific peripheral requirements. To support the 
large number of possible I/O configurations, 
sockets are provided for interchangeable I/O line 
drivers and terminators. Hence, the I/O interface 
provides the appropriate combination of optional 



line drivers and terminators to allow the required 
sink current, polarity, and drive/termination 
characteristics for each application. The 48 pro- 
grammable I/O lines and signal ground lines are 
brought out to two 50-pin edge connectors that 
mate with flat, round, or woven cable. 

A programmable communications interface using 
Intel's 825 1 Universal Synchronous/Asynchronous 
Receiver/Transmitter (USART) is contained on the 
SBC 80/10. A jumper selectable baud rate genera- 
tor provides the 8251 with all common communi- 
cation frequencies. The 8251 can be programmed 
by the user's system software to select the desired 
asynchronous or synchronous serial data transmis- 
sion technique (including IBM Bi-sync). The mode 
of operation (synchronous or asynchronous), data 
format, control character format, parity, and 
asynchronous transmission rate are all under pro- 
gram control. The 8251 provides full duplex, 
double buffered transmission and receive capabil- 
ity. Parity, overrun, and framing error detection 
circuits are all incorporated in the 8251. The in- 
clusion of jumper selectable TTY or EIA RS232C 
compatible interfaces on the board, in conjunction 
with the 8251, provide a direct interface to tele- 
types, CRTs, asynchronous and synchronous 
modems, and other RS232C compatible devices. 
The RS232C or TTY command lines, serial data 
lines, and signal ground lines are brought out to a 
25-pin edge connector that mates with RS232C 
compatible flat, round, or woven cable. 

Interrupt requests may originate from six sources. 
Two from the 8255's, two from the 8251 and two 

from user designated peripheral devices. 



TABLE 1 INPUT/OUTPUT PORT MODES OF OPERATION 



PORT 


NO. OF LINES 


MODE OF OPERATION 


UNIDIRECTIONAL 


BIDIRECTIONAL 


CONTROL 


INPUT 


OUl 


PUT 


UNLATCHED 


LATCHED & 
STROBED 


LATCHED 


LATCHED& 
STROBED 


1 


8 


X 


X 


X 


X 


X 




2 


8 


X 


X 


X 


X 






3 


8 


X 




X 








4 


8 


X 




X 








5 


8 


X 




X 








6 


4 


X 




X 










4 


X 




X 









1. Note: Port 3 must be used as a control port when either Port 1 or Port 2 are used as a latched and strobed input or a latched and 
strobed output or Port 1 is used as a bidirectional port. 



The 8255's can generate interrupts when a byte of 
information is ready to be transferred to the CPU 
(i.e., input buffer full) or a byte of information has 
been transferred to a peripheral device (i.e., output 
buffer is empty). 

The 8251 can generate interrupts when a character 
is ready to be transferred to the CPU (i.e., receive 
channel buffer is full) or a character is ready to be 
transmitted (i.e., transmit channel data buffer is 
empty). 

The user designated peripheral devices can generate 
two interrupts: one via the system bus and the 
other via the I/O edge connector. 

The two interrupts from the 8255's and the two 
interrupts from the 8251 are all individually mask- 
able under program control. The six interrupt 
request lines share a single CPU interrupt level. 
When an interrupt request is recognized, a RE- 
START 7 instruction is generated. The processor 
responds by suspending program execution and 
making a subroutine call to a user defined interrupt 
service routine originating at location 38 (Hexa- 
decimal). 

SBC 80/10 memory and I/O capacity may be 
increased by adding standard Intel memory and 
I/O boards. Modular expandable backplanes and 
card cages, each with a four-board capacity, are 
available to support multi-board systems. 

The development cycle of SBC 80/10 based prod- 
ucts may be significantly reduced using the Intellec 
Microcomputer Development System. The resident 
macro-assembler, PL/M-80 compiler, text editor, 
and system monitor greatly simplify the design, 
devleopment, and debug of user designed SBC 
80/10 system software. A diskette-based system 
allows programs to be loaded, assembled, edited, 
and executed faster than using conventional paper 
tape, card, or cassette peripherals. A unique In- 
Circuit Emulator (ICE 80) provides the capability 
of developing and debugging software directly on 
the SBC 80110. 

SBC CONFIGURATION OPTIONS 

The SBC 80/10 provides the user with a powerful 
and flexible I/O capability for both parallel and 
serial transfers. This section discusses the user 
programmable and jumper-selectable options, and 
bus interfacing. 

SERIAL I/O OPTIONS 

The serial I/O interface, using Intel's 8251 USART, 
provides a serial data communications channel that 



can be programmed to operate with most of the 
current serial data transmission protocols. There 
are three general areas of serial I/O options: 

1. choice of interface type, RS232C or current 
loop, 

2. baud rate and program-selectable mode 
options, 

3. choice of an interrupt mechanism. 

The user has the choice, through jumper connec- 
tions, of configuring the serial I/O logic to present 
either an RS232C or a 20 mA current loop inter- 
face to an external device. If an RS232C interface 
is used, the 8251 can assume the role of a "data 
set" or a "data processing terminal". This enables 
the serial interface to be connected to different 
devices such as modems and computer terminals. 

There are two factors which enter into the choice 
of baud rate. They are the actual clock frequency 
used to drive the transmit/receive clocks on the 
8251 and the baud rate factor selected by a pro- 
grammable mode instruction control word output 
by the processor to the 8251. The baud rate factor 
is used to effectively divide the 8251 transmit and 
receive clocks by 1, 16 or 64. During normal oper- 
ation a factor of 16 is selected for asynchronous 
transmissions from 9.6K to 300 baud. A factor of 
64 must be used to achieve a baud rate of 1 10. The 
baud rate factor is only applicable to asynchronous 
transmission, as all synchronous transmission is 
done with an implied factor of one. 

Before beginning serial I/O operations, the 8251 
must be program-initialized to support the desired 
mode of operation. The CPU initializes the 8251 
by issuing a set of control bytes to the USART 
device. These control words specify: 

• synchronous or asynchronous operation 
baud rate factor 

• character length 

• number of stop bits 
even /odd parity 
parity/no parity 

Refer to the SBC 80/10 Single Board Computer 
Hardware Reference Manual or the "8251 Applica- 
tion Note" for details on the control words used to 
direct the operation of the 8251. 

The serial I/O logic can be configured with differ- 
ent forms of interrupt request mechanisms. By 
connecting a jumper, the user can allow the 825 1's 
Receiver Ready output to generate an interrupt 
request. The Receiver Ready output goes high 
whenever the Receiver Enable bit of the command 



word has been set and the 8251 contains a charac- 
ter that is ready to be input to the CPU. The user 
can also choose to have the 825 1's Transmitter 
Ready or Transmitter Empty output activate the 
interrupt request. The Transmitter Empty goes 
high when the 825 1 has no characters to transmit. 
Transmitter Ready is high when the 8251 is ready 
to accept a character from the CPU. Both Trans- 
mitter Empty and Transmitter Ready are enabled 
by setting the Transmit Enable bit of the command 
word. Upon receiving an interrupt, the program 
can determine the actual condition which is 
responsible for the interrupt by reading the status 
of the 8251 device. 

PARALLEL I/O OPTIONS 

The parallel I/O interface consists of six 8-bit I/O 
ports implemented with two Intel 8255 Program- 
mable Peripheral Interface devices. Eight lines 
already have a bidirectional driver and termination 
network permanently installed. The remaining 40 
lines are uncommitted. Sockets are provided for 
the installation of active driver networks or passive 
termination networks as required to meet the 
specific needs of the user system. 

The primary considerations in determining how to 
use each of the six I/O ports are: 

1. choice of operating mode, 

2. direction of data flow (input, output or 
bidirectional), 

3. selection of interrupt mechanism, 

4. choice of driver/termination networks for 
the port's data path. 

Operating Modes. There are three basic operating 
modes that can be selected by the system software. 
The modes of operation will be described here in 
general terms, leaving it to the reader to obtain 
details from the SBC 80/10 Single Board Computer 
Hardware Reference Manual or the "8255 Applica- 
tion Note." 

Mode is a basic input/output functional con- 
figuration which provides simple input and out- 
put operations. No "handshaking" is required, 
data is simply written to or read from a specified 
port. The outputs are latched and the inputs are 
unlatched. 

Mode 1 is a strobed input/output functional 
configuration which provides a means for trans- 
ferring I/O data to or from a specified port in 
conjunction with strobes or handshaking signals. 
The outputs are latched and are accompanied by 



an output control line which indicates that the 
processor has loaded the output port with a data 
byte. The input data is latched when accompa- 
nied by its externally operated control signal. 

Mode 2 is a strobed bidirectional bus input/ 
output functional configuration which provides 
a means for communicating with a peripheral 
device or structure on a single 8-bit bus for both 
transmitting and receiving data. Handshaking 
signals are provided to maintain proper bus flow 
discipline in a manner similar to mode 1. 

Data Flow Direction. In addition to the choice of 
operating mode, the user may also specify the 
direction of data flow, input or output from the 
8255's. At the time of RESET, the 8255's are 
configured into the input mode until altered by a 
control word directed to the control word register. 
When an output mode control word is received, 
all of the data bits are set to the low output state. 

Interrupt Mechanism. When the 8255 is pro- 
grammed to operate in mode 1 or mode 2, control 
signals are provided that can be used as interrupt 
request inputs to the CPU. The interrupt request 
signals, generated from one of the ports (port C), 
can be inhibited or enabled by setting or resetting 
the associated interrupt enable flip-flop, using the 
bit set/reset function of port C. This function 
allows the programmer to mask the interrupts from 
specific I/O devices without affecting any other 
device in the interrupt structure. 

Driver/Termination Networks. Depending on the 
direction of data flow, the user will select the 
appropriate TTL line drivers and Intel terminators 
that are compatible with the I/O driver/terminator 
sockets on the SBC 80/10. The list of suitable line 
drivers includes those with inverting, non-inverting, 
and open collector characteristics. There are two 
types of terminators: a 220-ohm/330-ohm divider 
or a IK ohm pull-up. 

BUS INTERFACING 

The system bus interface logic consists of three 
general groups of circuitry: 

1. gates that accept the various bus control 
signals, the interrupt request lines, and the 
ready indications, and then apply these 
signals to the CPU logic elements, 

2. the system bus drivers, 

3. the failsafe circuitry which generates an 
acknowledgment during interrupt sequences 
and during those cycles in which an ac- 



knowledgment is not returned because a 
non-existent device was inadvertently ad- 
dressed. 

Bus Interface Signals. The following paragraphs 
describe portions of the system bus interfacing 
logic relevant to interfacing a user device to the 
SBC 80/10. (Note: Whenever a signal is active-low, 
its mnemonic is followed by a slash; for example, 
MRDC/ means that the level on that line will be 
low when the memory read command is true.) 

BCLK/ - Bus clock; used to synchronize bus 
control circuits on all master modules. BCLK/ 
has a frequency of 9.216 MHz. BCLK/ may 
be slowed, stopped or single stepped, if 
desired. 

INIT/ - Initialization signal; resets the entire 
system to a known internal state. 

BPRN - Bus priority input signal; indicates to 
the SBC 80/10 that a higher priority master 
module is requesting use of the system bus. 
BPRN suspends the processing activity and 
drivers of the SBC 80/10 until the signal goes 
low. 

BUSY/ - Bus busy signal; indicates that the bus 
is currently in use. BUSY/ prevents all other 
master modules from gaining control of the 
bus. BUSY/ is driven by the HLDA/ output 
from the SBC 80/10 in response to a BPRN 
input. It indicates that the bus is available. 

MRDC/ - Memory read command; indicates 
that the address of a memory location has 
been placed on the system address lines and 
specifies that the contents of the addressed 
location are to be read and placed on the sys- 
tem data bus. 

MWTC/ - Memory write command; indicates 
that the address of a memory location has 
been placed on the system address lines and 
that a data word has been placed on the 
system data bus. MWTC/ specifies that the 
data word is to be written into the addressed 
memory location. 

lORC/ - I/O read command; indicates that the 
address of an input port has been placed on 
the system address bus and that the data at 
that input port is to be read and placed on the 
system data bus. 

lOWC/ - I/O write command; indicates that the 
address of an output port has been placed on 
the system address bus and that the contents 



of the system data bus are to be output to 
the addressed port. 

XACK/ - Transfer acknowledge signal; the 
required response of an external memory 
location or I/O port which indicates that the 
specified read/ write operation has been com- 
pleted (that is, data has been placed on, or 
accepted from, the system data bus lines). 

AACK/ - An advance acknowledge, in response 
to a memory read or write command, that 
allows the memory to complete the specified 
operation without requiring the CPU to wait. 

CCLK/ - Constant clock; provides a clock signal 
of constant frequency (9.216 MHz) for use by 
optional memory and I/O expansion boards. 
The same signal is used to drive both CCLK/ 
and BCLK/. 

INTRl/ - Externally generated interrupt re- 
quest. 

ADRO/-ADRF/ - 16 Address lines; used to 
transmit the address of the memory location 
or I/O port to be accessed. ADRF/ is the most 
significant bit. 

DATO/— DAT7/ - Bidirectional data lines; used 
to transmit/receive information to/from a 
memory location or I/O port. DAT7/ is the 
most significant bit. 

Bus Acknowledges. Further distinction between 
transfer acknowledge (XACK/) and advance 
acknowledge (AACK/) is required. All external 
memory and I/O transfer requests must return 
XACK/ to the SBC 80/10 (even if AACK/ is also 
returned). XACK/ indicates that data has been 
placed on (read command) or accepted from (write 
command) the system data bus lines. AACK/ is an 
advance acknowledge in response to a memory or 
I/O port command. It has been provided because 
the 8080A samples the ready line before valid data 
is required on the bus. If this condition is properly 
anticipated, AACK/ can be returned before the 
data is actually read, thus allowing an earlier opera- 
tion to be completed. AACK/ should be used only 
with a thorough understanding of the additional 
information provided in the SBC 80/10 Single 
Board Computer Hardware Reference Manual. 

DMA Transfers. An external device can make DMA 
transfers to or from RAM expansion boards. The 
transfer is coordinated with the SBC 80/10 by 
means of two bus signals: bus priority input 
(BPRN) and bus busy (BUSY/). The first step in 
making a DMA transfer is to obtain control of the 



system bus. This is achieved by asserting BRPN to 
the SBC 80/10 and then waiting until the SBC 
80/10 returns BUSY/, indicating that it has relin- 
quished control of the system bus. When this step 
is completed the external device may proceed with 
its DMA transfers until it is finished. At that time 
BPRN should be removed to allow the SBC 80/10 
to regain control of the system bus. It should be 
noted that the SBC 80/10 is placed in a hold state 
when it does not have control of the system bus. 



APPLICATIONS 

The SBC 80/10 may be applied to a wide variety 
of applications. Specific applications in four areas 
are presented in this application note. They are 
presented to illustrate a broad spectrum of single 
board computer capabilities and to demonstrate 
the use of various system features. 

INSTRUMENTATION 

Microprocessors have been used in instrumentation 
for many tasks ranging from handling simple inter- 
face functions to control of the analog to digital 
conversion process. The use of a single board com- 
puter can further serve in the application of 
instruments themselves to laboratory or process 
control environments. It is quite often necessary in 
these applications to control instrumentation 
remotely. A number of rather expensive minicom- 
puter-controlled solutions now exist on the market 
as automatic test equipment (ATE) systems. The 
SBC 80/10 presents itself as a cost effective solu- 
tion in situations where the larger ATE systems are 
beyond economic justification. 

The SBC 80/10 can be the sole CPU element in 
the system, providing instrumentation control and 
computational capability; or it can supplement a 
larger host CPU by handling distributed processing 
requirements. 

Instrumentation Control Application Example 

Most instruments such as DVMs, counters, data 
loggers, synthesizers, etc., have optional data out- 
put units (DOUs) and/or remote control units 

(RCUs). It is particularly time consuming to inter- 
face each instrument's DOU/RCU with custom- 
digital logic. Until the recent IEEE-488 interface 
standard, there was little in common from one 
interface to the next. The parallel I/O lines of the 
SBC 80/10 provide a common interface element 
that can be adapted to a majority of the DOUs and 
RCUs available today by means of software. 
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Figure 2. Interface Block Diagram 



This instrumentation control application shows 
how the SBC 80/10 has been used to control and 
read the data from the data output unit (DOU) of 
a Fluke 8375 Digital Multimeter. 

Interfacing the SBC 80/10 to the Fluke 8375 DOU 

has been accomplished through the use of three 
parallel I/O ports shown in Figure 2. An 8-bit port 
has been used to read input data from the Fluke 
8375 DOU. Another 8-bit port has been used to 
control the multiplexing of data from the DOU to 
the SBC 80/10. And, an 8-bit port has been used to 
provide the required control and monitoring of the 
following DOU functions: busy flag, sample sync 
flag, timeout enable, external trigger and trigger 
inhibit. 

The following listing contains a complete program 
to provide the necessary interface control func- 
tions as well as an exercise program. The program 
Usting is interspersed with text that is used to 
clarify the elements of the program. 



mSTRnUENTATION CONTROL APPLICATION 

FLUKE 8375 DIGITAL MULTIMETER 
DATA OUTPUT UNIT (DOU) CONTROLLER 



The CSEG directs the ISIS-Il 8080 Assembler to 
generate a relocatable code segment. Relocatable 
code can later be placed at any memory address by 
Intel's LOCATE Program. This lets you write your 
program without worrying about the application's 
final memory configuration. 



9 

10 ; 
11 
12 
13 



6 



Equate Table. The following table is used to give 
symbolic names to the binary I/O port addresses. 
The names used later in the program increase 
readability. 
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15 ; 






16 ; EWATE tms. 


17 ; 






18 CWR 


HJJ 


(HH 


19 mm 


EW 


0E8H 


20 STB 


EW 


0E9H 


21 FLG 


Equ 


OEAH 


22 TSC 


EW 


CBW 


23 ; 






24 







8255 12 ONRCL WJD REGBIER 
ISaCE PAIR DBA INPUT PCKT 
SlBCffi OUHOT B3!T 
ILAG INPUT PCKF 
TRBGER ajlHjr PCKT 



Observing the schematic for the SBC 80/10 - 
Fluke 8375 DOU (Figure 3), it can be seen that the 
8255 #2 should be configured through the use of 
the mode control word as: 

Port 4 (A) Mode Input 

Port 5 (B) Mode Output 

Port 6 (C) Bits PC2-PC0 Output 

Port 6 (C) Bits PC5-PC4 Input 

The following mode control word is used: 



The exercise program uses some of the subroutines 
provided in the SBC 80/10 System Monitor 
PROMs. The addresses of the subroutines are 
included in the equate table. 



25 

26 ; 

27 GETCH 

28 CO 

29 CRtUT 

30 miT 

31 ; 

32 



EQU 

EQU 
EQU 



0220H 
01E8H 
01F3H 
02C2H 



GET crrecLE input, mask cjf parhy 
amxE ouiror 

PRINT <CR><LF> 
DBHAY BME IN ACCUM 



°1 °b D4 D3 D2 D, Do 



Port C Bits PC0-PC2 Output = 



Port B Output = Q 



Port B Mode = 



Port C Biti PC4-PC5 Input = 1 



Port A Input = 1 



Part A Mode ^ 00 



Opcode Mode Set = 1 



Mode Control Word ' 1001 1000 Binary = 9SH 



The use of the' SBC 80/10 parallel I/O ports 
requires that the mode of operation be defined for 
each port. This is typically done by an initializa- 
tion subroutine executed when the SBC 80/10 is 
powered up or reset. 

8255 Control Word. When the opcode field (bit 7) 
of a control word directed to an 8255 is equal to 
one, the control word is interpreted as a mode 
definition control word. The mode definition 
control word format is shown below; 



CONTROL WORD 



°7 










°2 




°0 



PORT C (LOWER = 
1 ■ INPUT 
OsOUTPUT 


PCj-PCo) 


PORTB 




1 =INPUT 




0=OUTPUT 




MODE SELECTION 
0- MODE 
1 = MODE 1 



PORTC (UPPER - PCj-PC-t 
1 -INPUT 
. OUTPUT 



PORTA 
1. INPUT 
0=OUTPUT 



MODE SELECTION 

00. MODE 
01 =MODE 1 
IX - MODE 2 



ZL 



1 - MODE SET 



33 
3" ; 

35 ; "' 

36 1 

37 INIT; 

38 
39 
40 ; 
41 



8255 12 INmALIZATTON SUBRCXJUNE 



MVI 

OUT 



A,1001lOOOB 
CWR 



; LD MODE CENIRCL WK) 

; OUltUT TD 825512 CNIL WD Iffi 



This coding loads the mode control word into the 
8255 #2 control word register. Additional initial- 
ization code is required to set the strobe and 
trigger output ports to an inactive state. The sche- 
matic shows that inverting drivers have been used 
for both the strobes and the trigger. When a com- 
mand is issued to place port 5 (B) into the output 
mode, bits PB7— PBO are set to the low output 
state. Because the low outputs are then inverted 
and used as strobes to the Fluke 8375, they must 
then be disabled. The initialization subroutine 
concludes by disabling the strobes and trigger. The 
strobes are signals to the DOU which enable its 
drivers to send data to the SBC 80/10. The trigger 
is a signal to the DOU that the Fluke 8375 should 
take a reading. 



12 
13 

44 
45 
46 
47 
18 
19 



MVI A.OFFH 

CUT STB 

our TSG 
RET 



UD MASK TO: 

DISABLE STRCBES 
DISABLE TRBGER 



External Trigger Control. Two subroutines are 
implemented to enable and disable the external 
trigger mode of the instrument. These subroutines 
use the bit set/reset capability of the 8255 to inde- 
pendently set or reset three control Mnes of the 
Fluke 8375 DOU. 



When the opcode field (bit 7) of an 8255 control 
word equals zero, the control word is a port 6 (C) 
bit set/reset command word. 

The bit set/reset control word format is shown 
below: 



CONTROL WORD 



SET/RESET FLAG 



= RESET BIT 

1 = SET BIT 



I NOT USED SET TO OOP 



^3 


°2 


D1 


PORT C BIT 











BIT 








1 


BIT 1 





1 





BIT2 





1 


1 


BIT 3 


1 








eiT4 


1 





1 


BIT 5 


1 


1 





BIT 6 


1 


1 


1 


BIT 7 



z: 



- BIT SET/RESET 



The following example demonstrates how the port 
6 (C) bit set/reset control word is constructed to 
disable the Fluke 8375 external trigger. Note from 
the schematic (Figure 3) that port 6 (C) bit con- 
trols the inhibit external trigger line. 



°7 



D3 



D2 



Do 



Bit Select . 000 [Binary) 



Not Used =OW (Binary) 



Bit Set/Reset Opcode = 



Ths control word lor set Part C bitO ii 0000 0001 Binary -01H 



■, •• • ENABLE EXTERNAL TRIGCER SUBROUTINE 'tt 

ETBIG; 



UVI A.OOOOOOOOB 
OUT CWH 

RET 



; LD RESET BIT CONTROL UKD 
; OUTPUT TO 825512 CNTL ifD REG 



••• DISABLE EXTERNAL TRIGGER SUBROUTINE • • 
DTRIG: 



UVI A.OOOOOOOIB 

OUT CUR 

RET 



; LD SET BIT CONTROL WSD 
: OUTPUT TO 825512 CNTL \t) RBS 



Subroutines to enable and disable the timeouts are 
written in an analogous fashion. The timeout 
enable line is controlled by port 6 (C) bit 2. 



' 1 ENABLE TIMEOUTS SUBROUTINE • • • 

EPOS: 



HVl A,00000101B 

OUT CUR 

RET 



LD SET BIT 2 CONTROL ftWD 
OUIPUT TO 825512 CNTL W) REG 



•" DISABLE TIMEOUTS SUBROUTINE 
DPOS: 



79 
80 
81 
82 
83 



UVI 
OUT 
RET 



A.OOOOOIOOB 
CUR 



LD RESET BIT 2 CONTROL TOD 
OUTPUT TO 825562 CNIL WD REG 



Obtaining Readings. The Fluke 8375 DOU allows 
readings to be taken in one of two modes. The 
first, a triggered mode, assumes that the external 
triggering has not been inhibited and requires the 
positive edge of a pulse with a minimum width of 
1 microsecond on the trigger input. Setting and 
resetting the port 6 (C) bit 1 produces the 8375 
external trigger. After a reading is triggered the 
8375 busy flag is tested until the not busy state is 
reached. At that time the reading that was 
triggered can be read by the SBC 80/10. The last 
statement in this routine jumps to TKDATA which 
reads the data from the DOU and then executes 
the return. 



84 
85 

86 
87 

88 TBGB: 



SUBROUTINE TO TAKE EXTERNALLY TRIGGERED READING ' • • 



89 


MVI 


A, 0000001 OB 


LD RESET BIT I CONIROL WJO 


90 


OUT 


OiW! 


OUTPUT TO 825512 CNIL KD REG 


91 


INR 


A 


MODIFY CONTROL WORD TO SET BIT I 


92 


OUT 


CUR 


OUTPUT TO 825512 CNTL KD REG 


93 TVT: 








94 


IN 


FLG 


INPUT THE BUSY FLAG 


95 


ANI 


00100000B 


TEST PORT C BIT 5 


96 


JNZ 


M 


LOOP UNTIL NOT BUSY 


97 


JHP 


iHDATA 


GO READ DATA FRCU DOU AND RETURN 



The second method for reading the Fluke 8375 is 
to rely on the sample rate set from the front panel 
controls and to wait until a full transition of the 
busy flag is observed. This guarantees that a previ- 
ous reading is not mistakenly interpreted as a new 
reading. 



100 
101 
102 
103 
101 



- til 

NXTRD: 



SUBROUTINE TO OBTAIN NEXT READING ••• 



105 


IN 


FLC 


INPUT THE BUSY FLAG 


106 


ANI 


OOlOOOOOB 


TEST PORT C BIT 5 


107 


JZ 


NXIRD 


LOOP UNTIL BUSY WIIH NEXT READING 


108 NXIWT: 








109 


IN 


FLG 


INPUT THE BUSY FLAG 


110 


ANI 


OOlOOOOOB 


TEST PORT C BIT 5 


111 


JNZ 


NXM 


LOOP UNTIL NOT BUSY 


112 


JHP 


TKDATA 


GO READ DATA FRCU DOU A^D REIURN 



113 

114 



Notice that the loops beginning at NXTWT in the 
above program segment and at TWT in the previous 
program segment are identical. This suggests the 
possibility of some obvious code optimization that 
is omitted here for the sake of clarity. 

There is one subroutine remaining to complete full 
utilization of the Fluke 8375 DOU capabilities. It 
is the subroutine to take data from the 8375 DOU. 
The schematic (Figure 3) shows that port 5 (B) bits 
PB4-PB0 are used to enable the DOU drivers. Data 
from the DOU includes: 

• 5 decades of digits 

• encoded range and overrange 



• function: Volts DC, Volts AC, Ohms, Kil- 

ohms 

• modifiers: Filter, Ext. Ref., Remote 

• overload 

• trigger 

The function of this subroutine is to read five 
bytes of data from the 8375 DOU and place them 
in a RAM buffer on the SBC 801 10. 



"5 








116 ; 








IIT ; ••• 


SUBROUTINE TO TAKE MIA ERCU 8315 WU *•• 


118 ; 








119 TKDATA: 






120 


LXI 


H.RDBUF 


LD BUFFER POINTER 


121 


NVI 


A,OEFH 


SETUP FIRST STROBE 


122 TKO; 








123 


MM 


B,A 


SAVE CURRENT STROBE 


124 


OUT 


STB 


STROBE DECADE PAIR 


125 


IN 


DATIN 


READ DATA 


126 


MJ/ 


H,A 


PLACE DATA INTO SBC 80/10 RAM 


121 


INX 


H 


INCRWENT BUFFER POINTER 


128 


MV 


A,B 


RESTORE STROBE 


129 


RRC 




ROTATE TO NEXT STROBE POSITION 


130 


JC 


TKO 


LOOP UNTIL BIT STROBE WNE 


131 


our 


STB 


DISABLE ALL STROBES 


132 


RET 






133 ; 








131 









This completes the software required to service the 
Fluke 8375 DOU. The following code consists of a 
routine to display the data from the interface on 
the console output device and a short executive 
program to allow exercising of the driver sub- 
routines. 

The display subroutine takes 5 bytes of data from 
the RAM buffer in which the reading has been 
stored and prints them, 2 ASCII characters per 
8-bit byte, on the console. 

135 

136 ; 

131 ; SUBROUTINE TO DISPLAY READING BUFFER CN CONSOLE ••• 

138 , 

139 DISPLAI: 



140 


LXI 


H.RDBUF 


LD BUFFER WINTER 


141 


MVl 


D,5 


INITIALIZE COUNTER 


142 DISPO: 








113 


MV 


AM 


W NEXT BYTE FRM BUFFER 


144 


CALL 


NM3Ur 


CALL SBC 80/10 MONITOR SUBROUTINE 


145 






TO DISPLAY ACCUMULATOR CONTENTS 


146 


DtX 


A 


INCRWENT BUFFER POINTER 


141 


OCR 


D 


DECREMENT COUNTER 


148 


JNZ 


DISPO 


LOOP BOR 5 DISPLAY BYTES 


149 


RET 







150 ; 
151 

Operator Interface. The short executive program 
provides a tool for the purposes of exercising the 
8375 DOU driver subroutines. The executive begins 
by calling the initialization subroutine and then 
continues on to prompt the operator with a '>' on 
the console. At that point the operator may enter 
one of the following characters, causing the pro- 
gram to execute the specified subroutine: 





SUBR 


DESCRIPTION 


T 


ETRIG 


Enable external trigger 


I 


DTRIG 


Disables external trigger 


E 


EPOS 


Enable programmed timeouts 


D 


DPOS 


Disable programmed timeouts 


N 


NXTRD 


Next reading 


S 


TRGR 


Trigger and get a reading 


X 


DISPLAY 


Display reading buffer 



After the operator has entered a command charac- 
ter, the program obtains the address of the sub- 
routine to be executed and proceeds to set up a 
return address on the stack. This technique allows 
a load program counter instruction (PCHL) to be 
used to enter the subroutine and a return instruc- 
tion (RET) to resume execution of the executive. 

152 

153 ; 

154 ; '•• SIMPLE EXECUTIVE EXERCISE PROORAM ••• 

155 ; 

156 START: 



157 




LXI 


SP, STACK 


SETUP STACK POINTER 


158 




CALL 


INIT 


INITIALIZE THE SBC 80/10 8255«2 


159 


EXEC: 








160 




CALL 


CROUT 


EXEC ENTRY POINT - PRINT <CR><LF> 


161 




HVI 


C,'>' 


C WADED WTH PRMPT CHARACIER 


162 




CALL 


03 


CONSOLE OUTPUT 


162 




CALL 


CBICH 


GET CUM3 CHAR. MASK OFF PARITY 


I6t 




CALL 


CO 


PRINT IHe CHARACTER ON THE CONSOLE 


165 




HOV 


A,C 


PUT CHARACTER BACK INTO THE ACCUM 


166 




LXI 


B.NCMDS 


C CONTAINS LOOP AND INDEX COUNT 


161 




LXI 


H.CTAB 


HL POINTS TO OMND TABLE 




EXBCO: 








169 




CUP 


M 


COMPARE TABLE ENTRY AND CHARACIER 


170 




JZ 


EXECl 


BRANCH IF EWAL - CMND RECOGNIZED 


171 




INX 


H 


USE, INCRWENT TABLE POINTER 


112 




DCR 


C 


DECREMENT LOOP COUNT 


173 




INZ 


lXECO 


BRANCH I F NOT AT TABLE END 


114 




lUP 


EXEC 


ELSE. CMND ILLEGAL - IGNORE IT 


175 


EXECl: 








178 




LXI 


H,CADR 


LD AER OF TABLE OF CHND SUBRS 


177 




D,4D 


B 


AID KHAT I S LEFT OF LOOP COUNT 


178 




DAD 


B 


- EACH ENTRY IN DTOR I S 2 BYTES 


179 




MJ/ 


A,M 


GET U P OF .«R OF TABLE ENTRY TO A 


180 




INX 


H 


WINT TO NXT BYTE IN TABLE 


iai 




ya 


KM 


GET MSP OF Am OF TABLE ENTRY TO H 


182 




MM 


L,A 


PUT U P OF ACR OF TABLE ENTRY TO L 


183 




LXI 


D,EXEC 


SETUP REIURN AER CN THE STACK 


184 




PUSH 


D 




185 




PCHL 




NEXT mSTR COMES FROM CMND SiJBR 



186 ; 
187 

The command and address tables as well as the 
reading buffer follow to complete the application 
software. 



188 






190 ■ COMMAND AND ADDRESS TABLES 


192 CTAB: 






193 


DB 


'XSNDEIT' 


194 mM& 


EQU 


*-CTAB ; NUMBER OF VALID COMMANDS 


195 ; 






196 CADR 






197 


a> 





198 


DX 


ETRIC 


199 


M 


Dime 


200 


S3* 


EPOS 


201 


DW 


DPOS 


202 


D* 


NXIRD 


203 


m 


TRCR 


204 


w 


DISPLAY 


205 ; 






206 ; READING 


BUFFER AND STACK SPACE 


201 ; 






208 RDBUF: 






209 


DS 


5 ; READING BUFFER 


210 : 






211 






212 






213 


END 


START ; TRANSFER ADDRESS I S TO START 



SUMMARY/CONCLUSIONS 

This instrumentation control application has been 
presented to demonstrate the simple techniques 
used to apply the SBC 80/10 to the task of inter- 
facing instrumentation. A natural extension of this 
example would include the control of the Fluke 
8375 RCU, as well as the control of many addi- 
tional instruments to build a small ATE system. 



FLUKE 8375 DOU 
IDATA OUTPUT UNIT 



BUSY FLAG 



SAMPLE SYNC 
FLAG 



TIMEOUTS 
ENABLE 
EXTERNAL 
TRIGGER 




Figure 3. Interface Schematic 



10 



COMMUNICATION 



SBC 80/10 



A diverse range of single board computer applica- 
tions exists in the field of communication. The 
increase in distributed processing generates require- 
ments for self-contained computers to control 
elements of a communication system, increasing 
both the throughput and reliability. 

There are many situations that necessitate monitor- 
ing and controlling a system from a remote site. 
Typical examples are systems that cover large geo- 
graphic areas or systems in dangerous environments 
for human operators. If the object system, which 
provides the actual parallel inputs and outputs to 
the plant, is far from the controlling system, you 
can lower costs by reducing the number of inter- 
connecting wires via the addition of multiplexers 
to both systems. In the extreme (and often desira- 
ble) case of reducing the interconnects to an 
absolute minimum, all communication between the 
systems takes place on a single serial data link. If 
large distances are involved, this link can be stand- 
ard telephone wires. For moderate distances, the 
link can be a single twisted pair. In either case, the 
equipment used to interface the object system to 
the serial link is called a supervisory control and 
data acquisition (SCADA) terminal. 

The decision to replace a multitude of intercon- 
nects with a SCADA terminal is largely economic. 
Cables and their associated drivers and receivers 
can represent a significant part of the total cost of 
a factory automation project, particularly if an 
electrically noisy environment requires the use of 
shielded cables. Any potential savings in cabling 
must, of course, compensate for the additional cost 
incurred by adding the SCADA terminal to the 
system. 

Communication Application Example 

A SCADA terminal demonstrates an industrial 
communication application of the SBC 80/10. The 
Intel® 825 1 USART provides the serial communi- 
cation link and the two Intel 8255 Programmable 
Parallel I/O devices provide 48 parallel lines for the 
object system. A block diagram of a SCADA 
terminal is shown in Figure 4. 

The task of the software in this SCADA terminal 
example is two-fold. First, it must continually scan 
its parallel inputs, transmitting the status of those 
lines in a bit serial mode using the USART. And 
second, it receives bit serial data from the USART 
which is to be used to update the parallel outputs. 
Thus, a major portion of the software deals with 




Figure 4. SCADA Terminal Block Diagram 



the communications protocol on the serial data 
lines. 

Communications Protocol. A communication pro- 
tocol is an agreement between communications 
users that defines the record formats used for data 
transmissions. The protocol selected for this 
SCADA terminal application provides the follow- 
ing features: 

1 . A readable character set to simplify the 
human interface. 

2. Error detection by means of a checksum. 

3. Each record specifies the number of data 
bytes in the record and the initial port 
number. 

Despite its value for human interface, the ASCII 
character set has problems representing 8-bit 
binary values, since the high-order bit is not used. 
Therefore, each binary value is treated as two 4-bit 
hexadecimal values. Because hexadecimal numbers 
fall in the range 0-9 and A— F, they can be repre- 
sented as ASCII characters. However, this repre- 
sentation requires twice as many bytes as a pure 
binary format. 

Record Format. The information encoded into the 
ASCII hexadecimal format is grouped to form 
records. Each record has a record mark to flag the 
beginning of the record, a number of ports specifi- 
fication (record length), destination output start 
port number, the data field itself, and a checksum. 

The record format described below is according to 
the fields in the record. 

Record mark field: Byte 

The ASCII code for a colon (:) is used to signal 
the start of a record. 

Number of ports field: Byte 1 

The number of data bytes in the record is repre- 
sented by a single ASCII hexadecimal digit in this 
field. This corresponds to the number of 8-bit 



ports to which data will be output by the 
SCADA terminal in a parallel fashion. The maxi- 
mum number of data bytes in a record is 15 (F 
in hexadecimal). A record length of zero is a 
special case and can be reserved for control 
information. 

Port address field: Byte 2 

The single ASCII hexadecimal digit in byte 2 
gives the port number of the initial output port. 
The first data byte is output to the port indi- 
cated by the port address; successive bytes are 
output in successive port locations on the SBC 
80/10 or on expansion I/O boards. 



encoding the serial output records. An examination 
of the serial input record state diagram (Figure 5) 
is useful in understanding some of the procedures 
encountered later. 



INIT 




HAC 



Figure 5. State Diagram 



Data field: Bytes 3 to 3-1-2 *(number of ports)- 1 

An 8-bit binary value is represented by two 
bytes containing the ASCII characters 0—9 or 
A— F, which represent a hexadecimal value 
between and FF (0 and 255 decimal). The 
high-order digit is in the first byte of each pair. 

Checksum field: Bytes 3-1-2 *(number of ports) to 
3-1-2 *(number of ports)-l-l 

The checksum field contains the ASCII hexa- 
decimal representation of the two's complement 
of the 8-bit sum of the 8-bit bytes that result 
from converting each pair of ASCII hexadecimal 
digits to one byte of binary, from the number of 
ports field (the number of ports and port ad- 
dress constitute a pair) to and including the last 
byte of the data field. Therefore, the sum of all 
the ASCII pairs in a record after converting to 
binary, from the number of ports field to and 
including the checksum field, is zero. 

Sample Hexadecimal format: 

: 3 . 3 A 1 7 8 F, F 

I Checksum Field 

' Data Field 

I Starting Port Addrerr 

I Number of Ports 

Record Mai* 

Design Approach Using a State Diagram. Before 
proceeding to examine the software used to imple- 
ment the SCADA terminal, consider how the prob- 
lem might have been approached with TTL logic 
rather than a microcomputer. The design would 
likely have been formulated with a state diagram to 
specify the transitions of a sequential state ma- 
chine. The sequential-circuit operations would 
include decoding the serial input records and 



Notes: HAC = Hexadecimal ASCII ctiaracter 

LHAC = Last Hexadecimal ASCII character 

PO = Parallel output l) 

The receipt of an invalid HAC will cause a return 
to state 0. 

The receipt of a colon at any time will produce a 
transition to state 1 . 



STATE DESCRIPTION 

= record mark state j( 

1 = number of ports state 

2 = start port number state 

3 = high-order half of data byte state 

4 = low-order half of data byte state 



State is entered at the time of initialization. All 
state transitions occur when the next character is 
received. States 1, 2, and 3 are entered with the 
input of a colon (:), the number of ports and start 
port number, respectively. States 3 and 4 will cycle 
as required until all the high and low-order pairs of 
data have been input. The transition from state 4 
to state occurs when the last data byte has been 
received. If the checksum is correct, the parallel 
output latches are loaded with the data field of 
the record. 

There are many references to the states contained 
in this diagram during the discussion of the soft- 
ware procedures. Thus, the state diagram is used as 
a "flowchart" for the software. As in the dther 
examples in this application note, a textual descrip- 
tion accompanies each segment of code. Intel's 
high-level programming language, PL/M-80, has 
been used to show the capability to program in a 
natural, algorithmic language which eliminates the 
need to manage register usage or memory alloca- 
tion. 



SCADA Terminal Program. The program begins 
with a comment, that is followed by the program 
segment label "SCADA". With resident PL/M-80, 
all programs are considered to be labelled blocks, 
or modules. This means that all PL/M programs 
must begin with a LABEL and a DO statement and 
end with an END statement. 



The serial input and serial output state counters are 
set to state 0. Port number is the parallel input 
start port and 3 ports of data are input from the 
parallel ports for serial transmission. 



5 2 SRLtlNtSTATE = 0; 

6 2 SRL$OUTtSTATE = 0; 

7 2 PRL$IN$STRT$PRT = 0; 

8 2 PRL$IN$NMB$PRTS = 3; 



INDUSTRIAL COMMUNICATION APPUCATION 



SCADA TERMINAL 



The Intel 825 1 USART must be set up by loading 
it with mode and command instructions. 

The mode instruction format is shown below: 



SCADA: 

DO: 



All variables used in the program must be declared 
before they can be referred to by their identifiers. 
This is done by means of a DECLARE statement. 
In addition to the declaration of variables, macros 
are declared using the reserved word LITERALLY. 
These macros are expanded at compile time by 
textual substitution. 



DECLARE 

SRLtIN»STAIE BYTE, 
SRLtlNjpRT BYTE. 
SRLtIN$CNT BYTE. 
PRL*IN$SIATE BYTE. 
PRL$INJSTRT$PRT BYTE. 
PRL$IN$NMMPBT3 BYTE. 
SRL$IN»PRL$0UT$BfR(3) BYTE, 

PRLIOUTtPBTtO LITERALLY 'OE^H", 
PRL»0UT»PRT$1 LITERAai 'OEAH', 
PHL)0UTjpRT$2 LITERALLY '0E8H', 

SRL$OUT$STATE BITE, 
SRL»OUT$PRT BYTE, 
SRLtOUT$CNT BYTE, 
PRL$OUT$STATE BYTE, 
PRL$OUT»STRT$PRT BYTE, 
PRLtOUTtNMBtPRTS BYTE, 
SRL^OTOPRLtlNtBFRCl) BYTE, 

PRL»IN»PRT10 LITERALLY '0E4H', 
PRLtlNtPBT^l LTTERALLY 'OESHi, 
PRL$INtPBTt2 LITERALLY '0E9H' , 

USART»CMD LITERALLY 'OEDH', 
USART»IN LITERALLY 'OECH', 
USABTtOUT LITERALLY 'OECH', 
USABT»STATUS LITERALLY 'OEDH', 
USAHT»MODE»INSTR LITERALLY 'OCFH' 
USAST$CMD»INSTB LITERALLY '025H', 

TXRDY LITERALLY '001H' , 
RXRDY LITERALLY '002H', 

PPI^CWR^I LITERALLY '0E7H', 
PPI$CWR^2 LITERALLY 'OEBH', 
PPI$CWDt1 LITERALLY 'O8OH', 
PPI*CWD$2 LITERALLY '09BH', 

TffiJE LITERALLY 'OFFH'. 
FALSE LITERALLY WOH', 

FOREVER LITERALLY 'WHILE TRUE', 



NEXT^BYTE BYTE, 
CHECiCSUM BYTE; 



8251 and 8255 Initialization. The INIT procedure 
sets up the 825 1 and 8255's and initializes several 
variables. Interrupts are disabled to insure that no 
interrupts are serviced during the execution of the 
INIT procedure. 



3 I INIT: PROCEDURE; 

4 2 DISABLE; 



1 

D7 1 Dg 


"5 1 D4 


1 

O3 1 D2 


D, 1 





BAUD RATE FACTOR 


• SYN MODE 

1 - ASYN XI 

1 • ASYN X16 
1 1 • ASYN X64 





CHARACTER LENGTH 



0-5 BITS 

1-6 BITS 

1 s 7 BITS 
1 I B BITS 



PARITY CONTROL 



XO - NO PARITY 

1 - ODD PARITY 

1 1 - EVEN PARITY 




^ NO - ASYN (D, Dq ;! 01 



FRAMING CONTROL 



- NOT VALID 

1 » 1 STOP BIT 

1 - I'A STOP BITS 
11-2 STOP BITS 



YES 

(Di Do-O) 



SYN CONTROL 



XO INTERNAL SYN 

X 1 EXTERNAL SYN 
OX DOUBLE SYN CHAR 
I X SINGLE SYN CHAR 



The 8251 characteristics required by this SCADA 
terminal application include 9600 baud transmis- 
sion and 8-bit characters. The parallel inputs of the 
8255's are periodically scanned. The scanning 
frequency is determined by the baud rate and 
number of ports of data being transmitted. For 
example, the transmission of 3 ports of data 
requires 1 1 characters. At a baud rate of 9600 the 
approximate scan rate is 100 Hz. 

The following 8251 mode instruction is used 



Baud Rate Factor = 10 
Character Length = 1 1 
Parity Control =00 
FramifTj Control = 11 



rnstruction -■ 1100 11 10 Binary = CEH 



After the mode instruction is sent to the 8251, a 
command instruction is required to complete the 
825 1 initialization. 

The command instruction format is shown below: 





06 


O5 


D4 


O3 


D2 


Dl 


Do 


EH 


IR 


RTS 


ER 


SBRK 


RxE 


DTR 


TxEN 



TRANSMIT ENABLE 
^ s ENABLE 
0- DISABLE 



DATA TERMINAL 

READY 
'•HIGH"WILL FORCE 
DTR OUTPUT TO ZERO 



RECEIVE ENABLE 
1 - ENABLE R«ROY 
= DISABLE RkROY 



SEND BREAK 

CHARACTER 

1 . FORCES TxO "LOW" 
- NORMAL OPERATION 



ERROR RESET 

T . RESET ALL ERROR 
FLAGS (PE,OE, FE) 



REQUEST TO SEND 
::ULGH"WILL FORCE 
RTS OUTPUT TO ZERO 



INTERNAL RESET 

"HIGH" RETURNS 8251 
TO MODE INSTRUCTION 

FOB.M.AT 



ENTER HUNT MODE 

1 = ENABLE SEARCH FOR 
SYN CHARACTERS 



Initialization of the 8255's is then done to set up 
the following configurations: 



8255 #1 

Port 1 (A) 
Port 2 (B) 
Port 3 (C) 

8255 #2 

Port 4 (A) 
Port 5 (B) 
Port 6 (C) 



ModeO 
Mode 
Mode 



ModeO 
ModeO 
ModeO 



Output 
Output 
Output 



Input 
Input 
Input 



The following command instruction is used for the 
8255 #1: 



D7 


D6 


D5 


D, 


D3 


D2 


Dl 


Do 



Port C Bus PC3-PC0 Output = 
Port B Output =0 



Port B Mode 0^0 



Port C Bits PC7-PC4 Output - 



Port A Output = 



Port A Mode = 00 



Opcode Mode Set = 1 



Mode Control Word = 1000 0000 Binary - 8QH 



The following command instruction is used for the 
8255 #2: 



The command instruction enables the transmit and 
receive functions of the 8251. 

The following command instruction is used 

[ 



rgnsrnii Enable - 1 
Data Termingi Ready = 
Receive Enable = 1 
Send Break Character = 
Error Reset = 
Request to Send - 1 
Internal Reset = 
— »■ Enter Hunt Mode = 



Instruction = 0010 0101 Binary = 25H 



Output instructions send the initialization com- 
mands to the 8251. Note that previously declared 
macros are used to literally replace the mnemonics 
in the following lines of code. 



D7 




D5 


D4 


D3 


D2 


Dl 


Do 



Port C Bits PC3-PC0 Input . 1 



Port B Input = 1 



Part B Mode 0=0 



Port C Bit! PC7-PC4 Input = 1 



Port A Input = 1 



Port A Mode = 00 



Opcode Mode Set = 1 



Mode Control WottJ . 1001 1 01 1 Binary . 9BH 



The 8255 initialization commands are given in a 
similar manner to the 8251 commands. 



11 2 0UTPUT(PPI$CWR$1) = PPI$CWD$1; 

12 2 0UTPUT(PPI$CWR$2) = PPI$CWD$2; 



The INIT procedure concludes by enabling inter- 
rupts. 



9 2 
10 2 



OUTPUT(USART$CHD) = USARi$MODE$INSTR; 
OUTPUK USART$CMD) = USART$CHD$INSTR; 



13 2 ENABLE; 

14 2 END INIT; 



Conversion Procedures. Two conversion procedures 
are required in the program. The first procedure 
produces a hexadecimal ASCII character from a 

4-bit binary value. A typed procedure has been 
used which returns a value of the type byte. It is 
called by using its name in an expression. 



15 1 CHAR$CONV: PROCEDURE (CHAR) BYTE; 

16 2 DECLARE CHAR BYTE; 

17 2 CHAR = CHAR t '0' i 
ia 2 IF CHAK > '9' THEN 

19 2 CHAR = CHAR + 7; 

20 2 RETDRB CHAR: 

21 2 END CHAP>CONV; 



The second procedure produces a 4-bit binary 
value from a hexadecimal ASCII character. Because 
this procedure is used only when a hexadecimal 
ASCII character is expected, an illegal character 
(i.e., not a 0-9 or A-F) causes the serial input 
state counter to indicate state 0. This procedure is 
also typed. The NMBSCONV procedure emphatic- 
ally illustrates the point that PL/M-80 performs 
unsigned arithmetic. Note that when the ASCII 
value for a zero is subtracted from the digit, 
NUM = NUM - '0'; a positive number is always 
produced, even if the value of NUM is less than '0'. 



22 1 NMB$CONVi PHOCEDDBE (NMB> BYTE; 

23 2 DECLARE NHB BYTE; 

24 2 NDB : NDB - '0' : 

25 2 IF NMB > 9 THEN' 

26 2 DO; 

27 3 IF (NMB > 16) Ate (NUB < 23) THEN 

28 S MJB = N W - 7: 

ELSE 

29 3 SRL>IN$STATE : 0; 

30 3 END; 

31 2 RETDRN NHS; 

32 2 END NMB$CONV; 



Parallel Input Procedure. A parallel input proce- 
dure is used to input data bytes from the 8255's. 
The data bytes are then transmitted by the bit 
serial output device. This procedure also computes 
the checksum for the serial output record. The 
checksum, TEMP2, is initialized to contain the 
parallel input number of ports and the start port, 
shifted to fit within a single byte. Each cycle of the 
iterative DO block adds the next data byte to the 
checksum and places the input data into the 
SRL$OUT$PRL$IN$BFR array until the loop is 
complete. The checksum is then computed as the 
two's complement of the accumulated sum and 
also stored in the serial input parallel output 
buffer. 



33 1 PARALLELtIN: PROCECORE; 

34 2 DECLARE (TEMPI, TEMPS) BYTE; 

35 2 i PRL$IN$MHB$PRTS • 16 + PRL$IN$STRT$PRT; 

2 PRL$IN$STATE : PRL$IN$STRTtPRT TO 

PRL$IN$STRT$PRT + PRL$IN$NMB$PRTS - 1; 

37 3 DO CASE PRL$IN$3TATE; 

/* PRL III PET "/ 
3a t TEMPI : INPUT(PRL$IN$PRT$0); 

/• PRL m PRT 1 V 

39 4 TEMPI : INPUT(PRL$IN$PRT$1) ; 

/• PRL m PHT 2 •/ 

40 4 TEMPI : INPUT(PRL$IN$PRT$2) ; 

41 4 END; 

42 3 SBL$0UTtPRLtIN$BFR(PRL$IN$3TATE) : TEMPI; 
13 3 TEMP2 = TEMP2 + TEMPI; 

It 3 END; 

15 2 S8LJ0UT$PRL$IK$BFR(PRLJIN$STRT$PI(T + PRLtINt((MB$PRTS) : -TENP2; 

46 2 END PARALLEL$IN; 

Parallel Output Procedure. When a complete serial 
input record has been received and the checksum is 
correct, the transition from state 4 to state is 
accompanied by the parallel output of the data 
from the data field of the serial input record. The 
parallel output starting port and the number of 
ports of data is contained in the input record and 
is thus used in directing the parallel output opera- 
tion. An iterative DO block increments the 
PRL$OUT$STATE index variable through the 
required ports and a DO CASE block selectively 
executes one of the OUTPUT statements for each 
cycle of the loop. 

47 1 PARALLEL$OUT: PROCEDURE; 

48 2 DECLARE TWP BYTE; 

19 2 DO PflL$OUTtSTATE = PRL$OUT$STRT$PRT TO 

PRL$0UT$3TRTtPRT * PRLtOUT(NMB$PRT3 - 1 ; 

» 3 TWP = SRHIN$PRLtOUT$BFR(PBLtOUT$STATE); 

51 3 DO CASE PRL$0UT$3TATE; 

/• PRL OUT PRT V 

52 4 ODTPUT(PRL$0UI$PRT$0> : TWP; 

/ * PRL OUT PRT 1 • / 

53 t OUTPUT(PRL$OUT$PRT$1) : TEMP; 

/* PRL OUT PRT 2 •/ 
51 1 0UTPUT(PRL$0UTtPRH2) : TWP; 

55 4 END; 

56 3 END; 

57 2 END PARALLEL$0UT; 

Serial Input and Output Procedures. The next two 
procedures contain the software implementations 
of the state diagram described previously. The 
processing during each state of the first procedure, 
the serial character input procedure, is described 
in the following text. 

The procedure begins by reading a character from 
the 8251 and then converts the character into a 
4-bit binary value using the number conversion 
procedure. The DO CASE block is the mechanism 
by which a program segment is selected to examine 



the input character, provide the required outputs, 
and to specify the transition to the next state. 



58 1 SERIAL$CHAHtIN: PROCEDDEE; 

59 2 DECLARE (CHAB.TEMP) BITE; 

60 2 CHAR ; INPUT(USABT»IN) SND 07FH; 
a 2 TWP : NrtB»CONV(CHAR); 

62 2 DO CASE SHL$IN$STATE; 



State is entered through the initialization proc- 
ess, at the completion of the processing of a serial 
input record, or when an invalid character has been 
received. The serial input state will remain until a 
colon (:) is received, at which time a transition to 
state 1 is specified. 

/• SRL IN STATE : RECORD t«RK •/ 

63 3 CO; 

64 4 IF CHfiR ; ' : ' IHEW 

65 4 SRL»INJSTATE : 1; 

66 4 END; 



The parallel output number of ports is obtained, 

the counter initialized, and a transition to state ^ is 
specified from state 1 . 

/• SRL m STATE ! = NMB PRTS •/ 

67 3 DO; 

68 * PRL»OUT»NMB$PRTS = TWP ; 

69 4 SRLtlNtCNT = TEMP: 

70 4 SRL$IN$STATE : 2; 

71 4 END; 



In state 2 the parallel output starting port number 
is obtained, the serial input port is initialized, the 
checksum is set to contain the parallel output 
number of ports and starting port, and a transition 
to state 3 is specified. 



/• SRL ra STATE 2 : STRT PRT •/ 

72 J DO; 

73 1 PRL$OUT$STRT$PRT = TWP ; 

74 t 3RL$IN$PRT : TEMP; 

75 4 CHECKSUM = PRL$0UT$NMB$PRTS«16 + PRL$OUT$STRT»PRT ; 

76 * SRL»IN$STATE : 3; 

77 * END: 



In state 3 the high-order half of a data byte is 
obtained and shifted into the proper position of 
the NEXT$BYTE variable. A transition is specified 
to state 4. 



/• SRI IN STKTE 3 ; HE CBDER HALF DATA BYTE •/ 

78 3 CO; 

79 t NEXItBrrE = TEMP«16; 

80 4 SRL$INJ3TATE = 4; 

81 4 END; 



State 4 is the final state and requires more process- 
ing than the others. First, a whole byte of data is 
assembled by adding the low and high-order data 
halves, and then testing to determine if the check- 
sum has been received. If so, and the checksum is 
correct, the parallel output procedure is executed. 
Once the entire serial input record has been re- 
ceived, a transition is specified to state whether 
the checksum is correct or not. However, if the 



serial input count has not been exhausted, the 
assembled byte is placed into the serial input 
parallel output buffer and a transition back to state 
3 is specified. 



/• SRL IN STATE H = LjO ORDER HALF DATA BITE •/ 

n? J DO; 

83 4 NEXTtBITE i NEXTtBYTE + TWP ; 

81 4 CHECKSUM ; CHECKSUM + NEXT$BHE; 

85 1) IF SRL»IN$CNT : THEN 

86 1 DO; 

87 5 IF CHECKSUM : MEN 

88 5 CALL PARALLEL$OUT; 

89 5 SRL|IN»STATE : 0; 

90 5 END; 

ELSE 

91 1 DO; 

92 5 SSLJINJPRLJOUnsFRCSSLHIIJPRT) : NEXT$BYTE; 

93 5 SRL»IN$PRT : SRL«IN»PRT + 1; 

94 5 SRL»IN$CNT : SRL»IN$CNT " 1; 

95 5 SRL(IN$STATE = 3; 

96 5 END; 

97 4 END; 

98 3 END; /• EMD OF CASES •/ 

99 2 END SERIAL»CHAR$IN; 



The serial character output procedure is similar to 
the serial character input procedure. During state 
the parallel inputs of the 825 5 's are stored in the 
serial output parallel input buffer for transmission. 



100 


1 


SERIAL$CHAR$OUT: PROCEDURE; 


101 


2 


DEdARE (CHAR, TEMP) BYTE; 


102 


2 


CHAR : 0; 


103 


2 


DO CASE SRL$OUT»STATE; 






/• SRL OUT STATE : RECORD MRK 


101 


3 


DO; 


105 


1 


CHAR ; ' : ■ ; 


106 


1 


CALL PARALLEL$IN; 


107 


1 


SRL(OUT$STATE .- 1; 


108 


1 


END; 






/• SRL OUI STATE 1 = NMB PRTS •/ 


109 


3 


DO; 


110 


4 


TIMP ; PRL$IN$NMB$PRTS; 


111 


1 


SRL$OUT$CNT : IMP : 


112 


1 


3RL$0UT$STATE ^ 2; 


113 


1 


END; 






/• SRL OUT STATE 2 : STRT PRT •/ 


114 


3 


DO; 


115 


4 


TEMP =. PRL$IN»3TBT$PRT; 


116 


4 


3RL$0UT$PRT = TMP ; 


117 


4 


3RL$0UT$3TATE : 3; 


118 


4 


END; 






/* SRL OUT STATE 3 : HI ORDER HALF DATA BYTE •/ 


119 




CO; 


120 


1 


TEMP = 3HR(3RL$0UT$PRL$IN»BFR(3RL$0UT$PBT),4); 


121 


4 


3RL$0UT$3TATE : 4; 


122 


4 


END; 






/• SRL OUT STATE 4 = 10 ORDER HALF DATA fllTTE •/ 


123 


3 


DO; 


124 


4 


TEMP : SRlJ0iJTJPBLtIIIJ8FR(SRLJ0IJTJPRT> AND OFH; 


125 


4 


IF 3BL$0UT$CNT s MEN 


126 


4 


SRL$OUT$STATE : 0; 






ELSE 


127 


4 


DO; 


128 


5 


3BL*0UT$C((T ; SBL$QUT$CNT " 1; 


129 


5 


3BL»0UI»PBT ■. 3BL$0UT»PBT + 1 ; 


130 


5 


SRL$0UT$3TATE = 3; 


131 


5 


END; 


132 


4 


END; 


133 


3 


END; /' EM) CF CASES •/ 


134 


2 


IF CHAR <> 1 ; ' THEN 


135 


2 


CHAR : CHAR$CONV(TEMP); 


136 


2 


OUTPUT(USARI$QUT) = CHAR; 


137 


2 


END SERIAL»CHAR$OUT; 



Interrupt Service Routine. The software in this 
SCADA terminal application example is interrupt 
driven. Interrupts, which occur when the trans- 
mitter of the 825 1 is ready for another character 
or when the receiver has obtained a serial charac- 
ter, direct the execution of either the serial input 



16 



or output character procedures. The following 
procedure is entered when an interrupt occurs. 

138 1 USARMINTERRUPT: PROCEDURE imERRDPT 7; 

139 2 DECIAKE STATUS BYTE; 

140 2 STATUS = INPUT(OSART$STATUS); 

141 2 IF (STATUS AHD TXRDY) = TXRDY THEN 

142 2 CALL 3ERIAL$CHAB$0UT; 

113 2 IF (STATUS AHD RXRDJ) = RXflDT THEN 

144 2 CALL SEBIAL$CHAB$IN,- 

145 2 END U3ART$INTERBUPT; 

Mifn Program. The function of the main program 
is rather simple. It calls the initialization routine 
and then loops "FOREVER." Notice that the 
other software is executed only when an interrupt 
occurs. Rather than loop idly while waiting for an 
interrupt, the "main program" could take advan- 
tage of excess CPU time by processing some other 
task. 



147 



MAIN$PROGBAM: 
•«/ 

CALL INIT; 

DO FOREVER; 



SUMMARY/CONCLUSIONS 

Further consideration should be given to error 
checking in the implementation of a SCADA termi- 
nal. A checksum has been used in this example 
which provides some error detection but no 
correction. 

The industrial communication example in this 
application note has shown a SCADA terminal. 
Besides providing a convenient forum in which to 
explore the use of PL/M in an interrupt-driven 
environment, this application provides a realistic 
and almost fully-developed tool for the replace- 
ment of a multitude of parallel lines. Two such 
systems can be connected through the serial lines 
to provide a parallel to parallel transmission 
scheme as shown in Figure 6. 



PARALLEL I/O 



PARALLEL 1/0 




SCADA TERMINAL 



SCADA TERMINAL 

=2 



Figure 6. Two SCADA Terminals 
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END; 



BIT SERIAL INTEHFACE 



SERIAL OUTPUT )> 



SBC 30/10 

IJ3 5) 



SERIAL INPUT 



SERIAL INPUT ^ 




<^ OUT > 




Figure 7. SCADA Terminal Schematic 



PROCESS CONTROL 

Many single board computers have already been 
applied in the field of process control. Some of the 
common denominators observed in these applica- 
tions include the use of A/D and D/A peripheral 
boards, process monitoring functions such as 
servicing display panels for operator interaction, 
and alarm indicators. 

Temperature Monitoring Application Example 

A temperature monitoring system has been devel- 
oped for the purposes of a process control applica- 
tion example. The single open loop system utilizes 
an A/D converter, a multiplexed display, switches 
for operator control, and two alarms. A block dia- 
gram of the operator's panel is shown in Figure 8 
and a schematic in Figure 9. 



TEMPERATURE MONITORING 
OPERATOR'S PANEL 



GROUP « 
8255 



PORT 5 (B( 



SWITCH 
INPUT 



7SEGMENT 
DATA 



DIGIT SELECTS. 

ALARM 

INDICATORS 



Figure 8. Operator's Panel Block Diagram 

Operator's Panel. The operator's panel in this 
temperature monitoring system contains four 
7-segment displays to show the temperature, two 
light emitting diodes (LEDs) that indicate alarm- 
low and alarm-high conditions, and six switches. 
The function of the switches is as follows: 

Set Limit - controls whether the current 
temperature reading is to be displayed (off) or 
if upper/lower limits are to be set (on). 

Set Hi Lo - when set limit is "on", this switch 
controls whether the low (off) or high (on) 
limit is to be displayed. 

Digit Selects - these two switches control the 
selection of the digit of the limit which is to 
be modified. The four binary positions 00, 
01, 10 and 11 correspond to the four 7- 
segment digits. 



Leave It - controls whether the digit selected 
is to be incremented (off) or maintained at its 
current value (on). When this switch is "off" 
the digit selected is incremented every 5 1 2 ms 
until the operator turns the switch "on". 

Enable Alarm - when set limit is "off" and the 
current temperature is displayed, this switch 
controls whether the action of the alarm indi- 
cators is to be enabled (on) or disabled (off). 

The simple means used to set upper and lower 
temperature limits is similar to setting the time on 
a digital wrist watch. 

The purpose of the software is to initialize the 
system and then to enter an endless loop which 
accumulates 16 readings, updates the displayed 
reading or handles limit setting, updates the display 
latches, waits 4 ms, and obtains an A/D reading. 

Temperature Monitoring Program. This application 
example has been coded in Intel's resident PL/M- 
80 language. 



PROCESS OONIROL APPLICATION 
OPEN LWP 
TEMPERATURE MONITOR 

V 

TEMPERATURE$MONITOR : 
DO; 



The declaration statement includes some dimen- 
sioned variables with INITIAL attributes. They 
provide data strobe positions, a table of bit pat- 
terns to convert BCD data to 7-segment data, and 
a table of the powers of 10 for binary to BCD 

conversions. 



DECLARE 

READING ADDRESS, 

DIGITS(l)) BYTE INITIAL (SOH.IOH.ZOH, lOH) , 
BCDT07SEG(11) BYTE INITIAL (3FH,06H,5BH,')FH,66H, 

6DH,7CH,07H,7FH,67H,0), 
TENS(ll) ADDRESS INITIAL (1000,100,10,1), 
DIGIT$DATA()|) BYTE, 
NXT$DIGIT BYTE, 
UPDATE$COUNT BYTE, 
SET$C0UNT BYTE, 
LIMIT(2) ADDRESS, 
ACCUM$RBNO ADDRESS, 

CUR LITERALLY 'OEBH', 
SLCT LITERALLY 'OEAH' , 
SEGS LITERALLY '0E8H', 
SXTS LITERALLY '0E9H' , 
SETUP$PORTS LITERALLY '082H', 

SET$LimT LTTERALLY 'OOIH', 
SET»H1$L0 LITERALLY 'OOiH', 
LEAVE$IT LITERALLY 'OlOH' , 
DIGiriSLCT LTTERALLY 'OXH', 
ENABLE$ALAfiM LITERALLY 'OZOH', 
SET$ALARM$LO LITERAIiY 'OOIH', 
SET$ALARM$HI LITERALLY '003H', 
RESEniLARMtLO LTIERALLY 'OOOH', 

I nn'>ur 

RESET$ALARM$HI LITERALLY '002H , 
TRUE LTTERALLY 'OFFH' , 
FOREVER LTTERALLY 'UHILE TRUE'; 



The analog to digital conversion procedure has 
been coded in assembly language and is not in- 
cluded in this application note. It is declared as an 
external typed procedure with no arguments and 
returns a value of the type address. The value 
returned is the current temperature. The ATOD 
procedure is linked later in a step to produce an 
absolute load module of the entire program. 

3 1 STCD: PRCCEDURE ADDIiESS EXTERNAL; 

4 2 END ATOD; 

Bit set/reset functions of the 8255 have been used 
to control the alarm-low and high output bits. Use 
of this function allows individual bits to be con- 
trolled without affecting others of port C which 
are concurrently selecting the digit to be multi- 
plexed on the display. 

5 1 RESETt ALARMS: PSCCEDBSE; 

6 2 OOTPUT(CWR) = RESET$/VURH$LO; 

7 2 OUTPUT(CHR) = RESET$ALARrt$HI ; 

6 2 EMD RE3ET|ALftRMS; 

The following procedure is used to initialize the 
8255 and several program variables. 

9 1 INIT: PRCCEDHRE; 

10 2 OUTPUT(CWR) = SETUP$PORTS; 

U 2 CALL RESET$ALARMS; 

12 2 NXT$DIGIT = 0; 

13 2 UPDATE$COUNT = 0; 

14 2 SET$COUNT = 7; 

15 2 READING ; 0; 

16 2 ACCUM$RDNC ; 0; 

17 2 LIMIT(O) = 0000; 

18 2 LIMIT(l) = 9999; 

19 2 END INIT; 

A multiplexed display is controlled by the soft- 
ware. Two ports of an 8255 are required for this 
function shown in Figure 9. The first output port 
holds the data which drives the four 7-segment dis- 
plays in parallel. The second output port contains 
four strobes, each going to a separate common 
cathode of one of the 7-segment displays. 

The update display procedure begins by blanking 
7-segment data in the output port. This step avoids 
shadows that would be produced if the data for 
the next digit position were loaded prior to up- 
dating the strobe. The strobe is then advanced, 
retaining the alarm bits that occupy other bits of 
the same output port. Note that an output con- 
figured 8255 port can be read with an 8080A 
INPUT instruction to determine the currently 
latched output data. The BCD data is obtained 
from the next digit position of the DIGIT$DATA 
array and used as a subscript into a table of 
BCDT07SEG data. The 7-segment data is also 



output to the 8255 port in the same statement. 
The procedure concludes by advancing the 
NXTSDIGIT pointer. 

20 1 DISPLAr$UPDATE: PRCCEHRE; 

21 2 0UTPUT(SEG3) = 0; 

22 2 OUTPUT(SLCT) = (DIGITS(NXT$DIGIT) CE (INPUT(SLCT> AND 03H)); 

23 2 OUTPUT(SEGS) = BCDT07SEa(DIGITtDATA(NXT$DIGIT)>; 

24 2 NXT$DIGIT = (NXT$DIGIT4.1) AND 03H; 

25 2 END DISPLAI$UPDATE; 

Binary to BCD Conversion. Binary data from the 
A/D converter must be converted to BCD before it 
can be used by the DISPLAY$UPDATE procedure 
to show the current temperature reading. The 
BINTOBCD procedure performs this conversion 
operation. 

36 1 BINTOBCD: PRCCEDHRE; 

27 2 DECLARE (BCD, I) BOTE; 

28 2 DO I = TO 3; 

29 3 BCD = 0; 

30 3 DO WHILE BEADING >= TENS(I); 

31 t BEADING - BEADING ~ TENS(I); 

32 4 BCD = BCD » 1; 

33 4 END; 

3t 3 DIGIT$DATA(I> = BCD; 

35 3 END; 

36 2 END BINTOBCD; 

BCD to Binary Conversion. The reverse conversion 
process is also needed. That is, BCD data must be 
converted to binary. This procedure is used to take 
limits, which are set by manipulating BCD digits, 
and convert them to binary data for use in testing 
against current temperature readings. Based vari- 
ables have been used in this procedure to allow 
access to the actual variables used as arguments in 
the calling program. 

37 1 BCMOBIN: PBCCEDOBE (BCD$ARRAJtADR,BIN$DATA$ADR); 

33 2 DECLABE 

(BCD»ARflAI$ADR,BIN$DATA*ADR) ADDBESS, 
(BCD«SRRAI BASED BCD$ARRAI$ADR) (H) BOTE, 
(BIN$DATA BASED BIN$DATA$ADR} ADDBESS, 
I BYTE; 

39 2 BIN$DATA = 0; 

40 2 DO I = TO 3; 

/• BIN$DATA = BIN$DATA«10 * BCDIABRAICl) •/ 

41 3 BIN$DATA = SHL(BIN$D*TA, 1) + SHL(BIN$DtTA,3) ♦ BCD»ARHAI(I) ; 

42 3 END; 

43 2 END BCDTOBIN; 

Updating the Display. The UPDATE procedure is 
entered each time 16 readings have been taken 
from the A/D converter. The UPDATE$COUNT is 
reset and the operator switches are input to control 
the execution path through the procedure. The 
accumulated reading, which is the total of 16 A/D 
readings, is divided by 16 to obtain an average 
reading. Then the accumulated reading is zeroed. 



44 1 UPDATE: PROCEDURE; 

45 2 DECLARE (SWT»FLC,HI*LO,DIGIT) BYTE; 



46 2 

47 2 

48 2 

49 2 



UPDATE»COUNT =15; 
SHT$fLG = INPunSHTS); 
READING = 3HR(ACCIJM$BDNG,1); 
ACCIJM$RDNG ; 0; 



The reading is compared with both the upper and 
lower limits if the alarms have been enabled. The 
results of the tests are used to set and reset the 
corresponding alarm output bits. 



Setting Limits. If the set limit switch is ON, the 
limits are to be dealt with instead of testing and 
displaying the current temperature reading. The 
alarms are reset during limit setting. The specified 
limit is converted to BCD and then the Leave-It 
switch is tested to see if the digit selected is to be 
incremented or held constant. 



50 
51 

5? 
53 
54 
55 

56 



IF (Sifl'IFLG AND 3ET$LI«IT) = SET»LIMlr THEN 
DO; 

CALL RESETtALARMS; 

HItLO = SHR((SHTtFLG AND SETtHItLO) , 1 ) ; 
READING = LIMIKHIJLO); 
CALL BINTOBCD; 

IF (SHTtFLG AND LEAVE»IT> <> LEAVEJIT THEN 



73 
74 
75 



79 
SO 



IF HEADING < LlmT(O) THEN 

OUTPIJT(CWR) : SET$ALARM$LO ; 
ELSE 

OOTPUT(CHS) : RESET$ALARrt$LO; 

If HEADING > LIMIT{ 1 ) THEN 

OUTPUKCHR) ; SETtALARMtHI ; 
ELSE 

OUTPUT(CWB) ; RESETJALARMtHI; 

END; 



If the alarms are not enabled, both the alarms are 
reset to the "off" condition. 



1 END; 

2 END UPDATE; 



ELSE 

CALL RESETtALARMS; 



Another counter is used to control digit incre- 
menting. Its purpose is to control the rate at which 
the selected digit is to be incremented. The major 
loop in the program has a 4-millisecond delay. 
Thus, 16 A/D conversions require a period of 
64 ms which provides an update frequency of 16 
readings per second. This is too fast to accurately 
select a desired digit which is being incremented. 
SETSCOUNT insures eight update periods (512 
ms) between each increment. After the digit has 
been incremented, the BCD limit value is con- 
verted back to binary to set the respective limit. 
This concludes the action taken when setting 
limits. 



57 
58 
59 
60 
61 
62 
63 

64 
65 
66 



67 1 

68 4 

69 3 



I F SETSCOUNT = THEN 
DO; 

SET$COUNT : 7; 

DIGIT = 3HR((SUT$FLG AND DIGITtSLCT) ,2) ; 
IF DICIT$DATA(DIGIT) : 9 THEN 
DIGITtDATA(DICIT) = 0; 

ELSE 

DIGIT$DATA( DIGIT) : DIGIT$DATA( DIGIT) + I; 
CALL BCDTOBIN( . DIGITtDATA , . LIHIT(HI$LO) ) ; 

END; 
ELSE 

SET$COUNT : SETJCOUNT " I; 



Testing the Averaged Reading. If the set limit 
switch is OFF, then the averaged reading is to be 
tested and displayed. The averaged reading is con- 
verted to BCD and then a test is performed to 
determine whether the reading is to be compared 
with the upper and lower limits. 



70 2 

71 3 

72 3 



ELSE 
DO; 



Main Program. The main program is shown below. 
Its purpose is to initialize the system and then to 
cycle, continuously executing the code previously 
described. 



MAIN$PROGRAM: 



81 

85 
86 
87 



90 
91 
92 



CALL INIT; 

DO FOREVER; 

ACCIJM$RDNC ; ACCUMtRDNG + READING; 

I F IJPD4TE$C0UNT ; THEN 

CALL UPDATE; 
ELSE 

IJPDATE$C0UNT ; 0PDATE$C01JNT - I; 

CALL DISPUY$UPDATE; 
CALL TIME(40); 
READING : ATOD; 



CALL BINTOBCD; 

IF (SWTIFLG AND ENABLE$ALARM) = ENABLE$AURM THEN 



SLTMMARY/CONCLUSIONS 

The goal of this application example is to demon- 
strate some of the common functions required for 
process control systems. Rather than show a small 
portion of a larger, more complex problem, this 
example was chosen because it presents a complete 
solution to a smaller problem. In summary, refresh- 
ing a multiplexed display was shown. Conversion 
procedures for binary to BCD and BCD to binary 
were used. A simple technique, in terms of hard- 
ware requirements, was used to enter lower and 
upper test values. And, limits testing was done, 
providing alarm indicators. 




Figure 9. Operator's Panel Schematic 



I/O DEVICE CONTROLLER 

Peripheral processors have become common ele- 
ments in computer systems of all sizes and capa- 
bilities. The purpose of such a processor is to 
relieve a central processor from the burden of 
handling I/O devices. In effect, it is a form of 
distributed processing. The SBC 80/10 can be used 
as a peripheral processor and/or as an I/O device 
controller. In such a capacity it can significantly 
reduce the amount of hardware required to inter- 
face peripherals. Because the SBC 80/10 controls 
only I/O, it is of little consequence that it must do 
a great deal of detail work that otherwise wastes 
the processing capability of a larger central 
processor. 

Consider the activity of producing a listing on a 
f line printer. The overhead in maintaining a pro- 
gram in the queue of a central processor which is 
producing data for a line printer can seriously 
impact system throughput. If, however, the pro- 
gram were to send the list to a disk file and then 
command a peripheral processor to take care of the 
printing, a significant improvement in system 
performance may be achieved. Printers represent 
one example of a large number of I/O devices that 
can be controlled by an SBC 80/10. Other devices 
include cassettes, magnetic tape drives, paper tape 
readers and punches, etc. 

Character Printer Controller Application Example 

The control of a Centronics 306 character printer 
is used as an I/O device controller application 
example. This example shows the interrupt capa- 
♦ bility of mode 1 8255 operation. A block diagram 
of the printer controller is shown in Figure 10 and 
a schematic in Figure 1 1 . 



CENTRONICS 
PRINTER 



PORT 3 (C) 



Figure 10. Printer Controiier Biock Diagram 



When the mode 1 or mode 2 configuration is used, 
software is generally required to support interrupts 
used in conjunction with handshaking operations. 
Software routines written for an interrupt driven 
environment tend to be more complex than status 
driven routines. The added complexity is because 
interrupt-driven systems are constructed such that 
other software tasks are run while the I/O transac- 
tion is in progress. A software routine that controls 
a peripheral device is generally referred to as a 
device driver. One method of implementing an 
interrupt-driven device driver is to partition the 
device driver into a "command processor" and an 
"interrupt service routine." The command proces- 
sor is the module that validates and initiates user 
program requests to the device driver. A common 
method of passing information between the various 
software programs is to have the requesting routine 
provide a device control block in memory. The 
device control block used in this application 
example is shown in Table 2. 



Tabie 2. Printer Software Controi Biock 



NAME 


POSITION 


DEFINITION 


Status 


Byte 


A l-byte field which defines the completion status of an I/O. 

00 = Good completion 

01 = Error - command already In progress. 


Buffer Address 


Byte 1, 2 


Pointer to the start of the data to print. 


Character Count 


Byte 3 


Count of the number of characters to print. 


Character 
Transferred Count 


Byte 4 


The number of characters transferred. 


Completion 
Address 


Byte 5, 6 


Address of a user supplied routine which will be called after the I/O has been 
performed. 



The command processor validates the transaction 
and initiates the operation described by the control 
block. Control is then returned to the requester 
so that other processing may proceed. The inter- 
rupt service routine processes the remainder of the 
transaction. 

Interrupt Service Routine Requirements. The 
interrupt service routine requires the following 
functions: 

1 . The state of the machine (registers, status, 
etc.) must be saved so that it' may be re- 
stored after the interrupt is processed. 

2. The source of the interrupt must be deter- 
mined. The hardware may support a register 
which indicates the interrupting device, or 
the software may poll the device status 
registers. 

3. Data must be passed to or from the device. 

4. Control must be passed to the requesting 
routine at the completion of the I/O. 

5. The state of the machine must be restored 
before returning to the interrupted program. 

Printer Controller Program. The software for this 
application has been coded using Intel® 8080 
Macro Assembly Language. 

S i 



2 ; 

3 ; 
t 1 

5 ; 

6 ; 

7 ; 



I/O DEVICE CONTROLLER APPLICATION 

INTERRUPT DRIVEN 
CHARACTER PRINTER 



The following program equates are used to allow 
symbolic reference to the 8255 ports. Group #1 
8255 on the SBC 80/10 has been used because it 
will support mode 1 operation. 



10 1 

11 ■■■•< 

1 2 ; 

It PORTA 

15 PORTB 

16 PORTC 

17 CMS 



PROaRAN EQUATES 



EQU 
EQU 
EQU 
EQU 



DEUH 
i)E5H 
dE(>H 
0E7rf 



8255 PORT A 
8255 PORT B 
8255 PORT C 

825 5 CONTROL WORD REGISTER 



An initialization control word sent to the control 
word register of the 8255 will set up the desired 
configuration. 



INmALIZATIOH CONTROL WORD 

USED TO CO^■FIGURE: THE 8255 AS FOLLOWS: 

PORT A - OUTPUT HODE 1 

PORT B - INPUT MODE (NOT USED) 

PORT C LOWER - OUTPUT 



ICW EQU lOlOlOlOB 



INITIALIZATION CONTROL WORD 



The bit set/reset capability of the 8255 is used to 
control the strobe to the printer and to enable/ 
disable interrupts from the 8255. 



32 ; 

33 ; 

34 STBON 

35 STBOF 

36 ;•««•• 

37 ; 

39 i'eN 

40 IDN 

111 ;""* 



SET/RESET CONTROL WORDS 



EQU 
EQU 



0000000 IB 

OOOOOOOOB 



SET STROBE 
RESET STROBE 



8255 ENABLE/DISABLE INTERRUPT CONTROL WORDS 



EQU 
EQU 



000011016 
00001 tOOB 



ENABLE INTERRUPTS 
DISABLE INTERRUPTS 



Device status, control block, and completion 
equates are shown below. 



DEVICE SiAIOS EQUATES 



LPBSr 
INTRA 
■»»»#♦ 



EQU 
EQU 



080H 
08H 



BUFFER FULL (LINE PRINTER BUSY) 
INTERRUPT REQUEST 



CONTROL BLOCK EQUATES 



CMT 
CBUF 
CBCC 
CBCT 
CBCMP 



EQU OOH 

EQU OIH 

EC3U 03H 

EQU OIH 

EQU 05II 



STATUS BYTE 
BUFFER ADDRESS 
CHARACTER COUNT 
CHARACTER TRANSFERED COUNT 
COMPLETION SERVICE ADDRESS 



; COMPLETION STATUS EQUATES 

irQQ EQU OOH 
STEl EQU OIH 



GOOD COMPLETION 

ERROR - COMMAND ALREADY IN PROGRESS 



There are two origin statements in this program. 
The first origin at 38 hexadecimal is the entry 
point used when an interrupt is generated by the 
8255. A jump instruction to the printer interrupt 
routine is stored at that location. The second 
origin at 3000 hexadecimal is the address where 
the rest of the code will be located. 



6 ; RESTART 7 ENTRY POINT 
^1 'imiift 

62 ORC 0038H 

6 3 IMP PINT 

6 5 ; PROGRAM ORIGIN 
66 ;••••» 

Sa 30O0H 



An initialization subroutine issues the mode con- 
trol word to the 8255 control word register after 
reset of the device. The printer strobe must then be 
disabled. 



70 i 

71 ; 

72 ; 

74 ;i**tt 



7 5 INIT: 

7 6 HVl 

7 7 OUT 

7 8 MVI 

7 9 OUT 

8 RET 

ai 



INITIALIZATION ROUTINE 
A,H,L REGISTERS MODIFIED 



A, lew 
CHR 

A, STBON 
CWR 



GET MODE CONTROL WORD 
OUTPUT TO CONTROL WORD REGISTEH 
GET SET DATA STROBE CONTROL WORD 
SET DATA STROBE (LOW TRUE SIGNAL) 
RETURN TO CALLER 



The command processor is started by the user 
routine through a subroutine call to PSTRT, with 
the address of the control block in the D and E 
registers. The command processor insures that an 
I/O operation is not already in progress, starts the 
I/O, enables interrupts, and returns to the caller so 
that other processing may proceed. 



The flowchart and hsting for the command proces- 
sor are shown below. 




90 
91 
92 
93 

94 PSTHT: 

95 

96 

97 

98 

99 
100 
101 
102 
103 
101 
105 
106 
107 
108 



109 
110 
111 
112 P3TE: 
113 
111 
115 



SET 

COMMAND 
IN PROGRESS 






CLEAR 
CT 













ERROR 







(POST TO \ 
USER / 



/ CALL \ 
( OUTPUT > 
\ DATA / 



ENABLE 
PROCESSOR 
INTERRUPTS 



^ RETURN ^ 



COtKAND PBOCESSOB 



INPUTS: CONTROL BLOCK ADDRESS IN D AND E HEGISTERS 
OUTPUTS: STAHT 1/0 OR ERHOR STATUS IN CONTROL BLOCK 



A,H,L 


REGISTERS 


MODIFIED 


LDA 


PIPROl 


; GET PRINT IN PROGRESS BLOCK ADDRESS 


ANA 


A 


; SEE IF ZERO (PRINT IN PROGRESS) 






; IF BLOCK ADDRESS NOT EQUAL TO ZERO THEN 






; PRINT IN PROGBESS 


JNZ 


PSTE 


; IF lES - BRANCH TO ERROR 


XCHG 






SHLD 


PIPRG 


; SAVE CONTROL BLOCK ADDRESS 


XCHO 






LXI 


H.CBCT 


; GET INDEX TO CT 


DAD 


D 


; COMPUTE ADDRESS OF CT 


MVl 


M.OOH 


; CLEAR CT 


CALL 


PDATA 


; START I/O 


EI 




; ENABLE PROCESSOR INTERRUPTS 


RET 




; RETURN tO CALLER 


ERROR 


- TRANSACTION ALREADr IN PROGRESS 


MVI 


A.STEl 


; GET ERROR STATUS CODE 


JMP 


POST 


; PASS CONTROL TO COMPLETION ROUTINE 



Interrupt Processing. When the 8255 generates an 
interrupt, the interrupt request is serviced by the 
8080A CPU. The CPU disables processor interrupts 
and then executes the instruction at location 38 
hexadecimal, which is a jump to the interrupt 
service routine. The interrupt service routine saves 
the processor state and polls the 8255 to determine 
the source of the interrupt. Once the interrupting 
device is identified, the printer output data routine 



is called. After the entire buffer has been printed, 
the interrupt service routine passes control to the 
user-suppHed completion routine. Before returning 
from the interrupt, the state of the processor is 
restored. 

There are a number of error conditions which may 
occur, such as an interrupt from a device that does 
not have an active control block, or an interrupt 
when polling establishes that no device requires 
service. Neither of these errors should occur, but if 
they do, the driver should perform in a consistent 
fashion. The recovery routines implemented to 
handle these interrupt error conditions are deter- 
mined by the environment of the particular appli- 
cation. 

The flowchart and listing for the printer interrupt 
service routine are shown below. 




RESTC 
REGIE 


3RE 
TERS 






ENABLE 

PROCESSOR 

INTERRUPTS 






^ RETURN 



116 
117 
118 
119 
120 
121 
122 
123 
121 
125 
126 



PRINTER INTERRUPT SERVICE ROUTINE 
ALL REGISTERS SAVED AND RESTORED 



PUSH PSW ; SAVE PSH 

PUSH B ; SAVE REGISTER PAIR B AND C 

PUSH D ; SAVE REGISTER PAIR D AND E 

PUSH H ; SAVE REGISTER PAIR H AND L 



25 



1S7 




POLL INTEBRUPT SOURCE - SEE OF 8255 


165 








128 


















129 




IN 


PORTC 


GET STATUS OF DEVICE 


167 ; 








130 




AN I 


INTRA 


SEE IF INT 


1AQ I 


PRINTER 


OUTPUT DATA ROUTINE 


131 




JZ 


PPOLL 


NO -BRANCH TO POLL OTHER DEVICES IF ANY 


169 ; 








132 




MVI 


A.IDN 


GET 8255 INT DISABLE CONTROL WORD 


170 ; 


CONTROL 


BLOCK ADDRESS IN D AND E REG 


133 




OUT 


CWR 


DISABLE DEVICE INTERRUPTS 


171 ; 








131 




EI 




ENABLE PROCESSOR INTERRUPTS 










135 




LHLD 


PIPRG 


GET CONTROL BLOCK ADDRESS 










136 




XHA 


A 


CLEAR A REG 


171 


TM 


PORTC 


GET STATUS OF DEVICE 


137 




CMP 


H 


SEE IF PRINT IN PROGRESS 


175 




LPBSY 


SEE IF BUSY (BUFFER FULL) 


138 




JZ 


PIERl 


NO - BRANCH TO ERROR ROUTINE 


176 


JZ 


PDIO 


IF BUSY - BRANCH 


139 




XCHO 










H.CBCT 


GET INDEX TO CT 


110 




CALL 


■■DATA 


PRINT DATA 


178 


nan 
J~ 


D 


COMPUTER ADDRESS OF CT 


111 










179 




A,H 


GET CT 


112 




RESTORE 


REGISTERS AND RETURN FROM INTERRUPT 


180 


TWO 


M 


INC CT 


113 


•ffff»i 








181 


XX 


H 


DEC TO CC 


111 PRTN: 








182 


CMP 


M 


SEE IF EQUAL 


115 




POP 


H 


RESTORE REGISTER PAIR H AND L 


183 


JZ 


PCOMP 


IF EQUAL - DONE GO TELL USER 


116 




POP 


D 


RESTORE REGISTER PAIR D AND E 


1£J1 


LXI 


H.CBUF 


GET INDEX TO BUFFER ADDRESS 


117 




POP 


B 


RESTORE REGISTER PAIR B AND C 


185 


DAD 


D 


COMPUTE ADDRESS OF BUFFER ADDRESS 


11(J 




POP 


PSW 


RESTORE PSW AND A 


186 


PUSH 


D 


SAVE D AND E REGISTERS 


119 




EI 




ENABLE PROCESSOR INTERRUPTS 


187 


MOV 


E,M 


GET LSB OF BUFFER ADDRESS 


150 




RET 




RETURN TO INTERRUPTED PROCESS 


188 


INX 


H 


INC TO NEXT BYTE 


151 










189 


MOV 


D,M 


GET BUFFER MSB 


152 




POLL OTHER DEVICES IF ANY 


190 


MVI 


H.OOH 


CLEAR H REG 


153 






IF NO OTHER DIVICES TO POLL - USER SUPPLIED ERROR 


191 


MOV 


L,A 


GET CT 


151 






RECOVERY 


ROUTINE. 


192 


DAD 


D 


COMPUTER CHARACTER ADDRESS 


155 


•ff##ft 








193 




A,M 


GET CHARACTER 


156 PPOLL: 








191 


OUT 


PORTA 


OUTPUT CHARACTER TO PRINTER 


157 




JMP 


PRTN 


RETURN 


195 


MVI 


A.STBOF 


RESET DATA STROBE (LOW TRUE SIGNAL) 


158 


«*ffff« 








196 


our 


CWR 




159 




ERROR - 


INTERRUPT FROM IDLE DEVICE 


197 


INR 


A 


GENERATE SET CONTROL WORD 


160 






USER SUPPLIED ERROR RECOVERY ROUTINE 


198 


OUT 


CWR 


SET DATA STROBE 


161 


Vffftftft 








199 


POP 


D 


RESTORE CONTROL BLOCK ADDRESS 


162 PIEfil: 








200 


JMP 


PDATA 


LOOP UNTIL BUSY 


163 
161 




JHP 


PRTN 


RETURN 


201 









The printer output data routine places a character 
in the output buffer of the 8255. Data in the 
control block is used to direct the transfer of a 
character. A data strobe signal is then generated 
through the use of the port C bit set/reset feature. 

The flowchart and hsting for the printer output 
data routine are shown below. 



If the printer is busy at the time the printer output 
routine is called, a printer busy routine is executed. 
The printer busy routine disables the processor 
interrupts, enables the 8255 interrupts and then 
enables the processor interrupts on its return to 
the caller. 





• 


DISABLE 
PROCESSOR 
INTERRUPTS 
ENABLE 8255 
INTERRUPTS 










202 
203 
201 ; 

205 ;•••»• 

206 PDIO: 
207 

208 
209 
210 



PRINTER BUSY - RETURN 



DI 
MVI 
OUT 
RET 



A.IEN 
CWR 



DISABLE INTERRUPTS 
ENABLE DEVICE INTERRUPTS 
SET INTERRUPT ENABLE 
RETURN TO CALLER 



UPDATE 
CT 



When the printer output routine has exhausted the 
data from the buffer, a good status code is posted 
to the user. The command in progress flag is also 
cleared. 



^ return"^ 




211 
212 
213 
211 PCOMP: 



POST GOOD COMPLETION TO USER 



215 


MVI 


A.STGD 


; GET GOOD STATUS CODE 


216 


CALL 


POST 


; POST TO USER 


217 


XRA 


A 


; CLEAR A REG 


218 


STA 


PIPRG* 1 


; CLEAR COMMAND IN PROGRESS ADDRESS 


219 


RET 




; RETURN TO CALLER 



GET CHAR 






OUTPl 
CHAR 
GENE 
STROE 


JT 

ftCTER 

3ATE 

SE 



STORE 
STATUS 



The post to user completion routine obtains the 
completion address from the device control block 
and passes control to the user routine. 



/ POST TO \ 
\ USER / 

^ RETURN ^ 



221 
222 
223 
221 
225 
226 
227 

228 i 

229 1 

230 ; 

231 ; 

232 ; 

233 ; 
231 ; 



POST TO USER COMPLETION ROUTINE 



STATUS CCOE IN A REG 

CONTROL BLOCK ADDRESS IN D AND E REG 

PASSES CONTROL TO USER COMPLETION ADDRES 

SPECIFIED IN CONTROL BLOCK 

WITH CONTROL BLOCK ADDRESS IN D AND E HE 



A,H,L,B,C REG MODIFIED 



26 



235 POST: 








236 


XCHG 






237 


MOV 


M,A 


UPDATE STATUS 


238 


XCHG 






239 


UI 


H.CBCMP 


GET INDEX TO COMPLETION ADDRESS 


210 


DAD 


D 


COMPUTE ADDRESS 


211 


MOV 


CM 


GET LSB OF COMPLETION ADDRESS 


212 


INX 


H 


INC TO NEXT BYTE 


243 


MOV 


B,H 


GET MSB OF COMPLETION ADDRESS 


244 


PUSH 


B 


PUSH ADDRESS ON STACK 


215 


BET 




PASS CONTROL TO USER ROUTINE 


246 ;•«••• 








247 ; 


DATS 


AND TABLES 




248 








249 


OBG 


3D00H 




250 PIPRG; 


DU 





IN PROGRESS CONTROL BLOCK ADDRESS 


251 






IF DATA = NO CONTROL BLXK IN PROGRESS 


252 






IF DATA <> CONTROL BLXK IN PROGRESS 


253 








254 ; 


END OF MODS ONE EXAMPLE 


255 








256 


END 







CENTRONICS 306 



SUMMARY/CONCLUSIONS 

The SBC 80/10 has the capabiHty to function in 
the capacity of a peripheral processor and/or a 
device controller. This capability is provided in 
part by the interrupt support logic accompanying 
the parallel I/O ports. This apphcation example 
shows how the SBC 80/10 requires only an inter- 
connect to the device to be controlled. 



GROUP =1 
8255 



PA7 

PA6 

PA5 

PA4 
PORT 1 lA) 
PA3 

PA2 

PAl 

PAo 



PC6 
ACKA 



IJ1-39I 



Figure 11. Printer Controller Schematic 



CONCLUSIONS 

The purpose of this application note has been to 
expose the reader to a broad spectrum of potential 
applications of the Intel SBC 80/10 and System 
80/10 products. Applications have been presented 
in the areas of instrumentation, communication, 
process control and I/O device control. The exam- 
ples were limited to short problems that could be 
completely described. 

Intel's PL/M-80 and 8080 Macro Assembly Lan- 
guage were both used in the examples. Instead of 
using only assembly language, it was felt that 
PL/M-80 should also be shown. Coding in an 
algorithmic language is generally more natural than 
assembly language and provides these added bene- 
fits: reduced program development time and cost, 
improved product reliability, and easier program 
maintenance. 



While the task of actually configuring the SBC 
80/10 for the applications has not been described 
in this note, detailed instructions are contained in 
the tables of Chapter 4 in the SBC 80/10 Single 
Board Computer Hardware Reference Manual. 

The Intel SBC 80/10 has been designed to provide 
users with subsystems that have processing power, 
memory storage, parallel and serial programmable 
I/O interfaces. A design goal of the SBC 80/10 was 
to minimize the requirements for customized 
interface hardware in user apphcations. This 
application note has demonstrated the achievement 
of this goal. The net effect is to reduce the number 
of tedious design tasks, thus allowing the systems 
designer to concentrate on systems integration and 
other problems unique to his job. 
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APPENDIX A 
SBC 80/10 SCHEMATICS 
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1703 Hillside Drive N/W 
Cedar Rapids 
Tel: (319) 396-5882 

KANSAS 

Technical Representatives, Inc. 

801 CJairborne 

O lathe 66081 

Te): (913) 782-1177 

TWX; 910-749-6412 

MARYLAND 

Glen White Associates 
57 West Timonium Road 
Timonium 21093 
Tel; (301) 252-7742 
Intel Corp.* 

57 West Timonium Road 
Suite 307 
Timonium 21093 
Tel: (301) 252-7742 
TWX; 710-232-1807 



EUROPEAN MARKETING OFFICES 



BELGIUM 

Intel International' 
Rue du Moulin 6 Papier 
51-Bolte 1 
B-1 160 Brussels 
Tel: (02) 660 30 10 
TELEX: 24814 



FRANCE 

Intel Corporation, S.A.R.L.' 
74, Rue D'Arcueil 
Silic 223 

94528 Rungis Cedex 
Tel: (01) 687 22 21 
TELEX: 270475 



ORIENT MARKETING OFFICES 

JAPAN 

Intel Japan Corporation' 
Rower HiH-ShinmachI East BIdg. 
1-23-9, Shinmachi, 5etagaya-l(u 
Tokyo 1 54 
Tel: (03) 426-9281 
TELEX: 781-28428 



HONG KONG 

01 (Far East) Ltd. 
Tak Yan Commercial BIdg. 6th lloor 
30-32 D'Aguiiar Street, Central 
Hong Kong 
Tel: 5-260311 
TELEX: 83138 JADE HX 



MASSACHUSETTS 

Intel Corp." 

187 Billerica Road, Suite 14A 

Chelmsford 01824 

Tel: (817) 256-8567 

TWX: 710-343-6333 

Computer Marketing Associates 

235 Bear Hill Road 

Wallham 02154 

Tel: (617) 890-1776 

MICHIGAN 

Intel Corp. 

28500 Northwestern Hwy. 
Suite 401 
SoutMleld 48075 
Tel: (313) 353-0920 
TWX: 910-420-1212 
TELEX: 2 31143 

Carter, McCormic & Peirce, Inc. 
23995 Freeway Park Drive 
Farmington Hills 48024 
Tel: (313) 477-7700 

MINNESOTA 

Intel Corp. 

675 SouthgateOHIce Plaza 
5001 West 80th Street 
Bloomington 55437 
Tel: (612) 835-8722 
TWX; 910-576-2887 
Data Electronics 
P.O. Box 32087 
Minneapolis 55432 
Tel: (812) 786-9866 

MISSOURI 

Technical Representatives, Inc. 

Trade Center BIdg. 

300 Brookes Drive, Suite 108 

Haze I wood 83042 

Tel: (314) 731-5200 

TWX: 910-782-0818 

NEW JERSEY 

Intel Corp. 
2 Kilmer Road 
Edison 08817 
Tel: (201) 985-9100 
TWX: 710-480-8238 
O, E. D. 

2916 Federal Street 
Camden 08105 
Tel: (215) 925-8711 

NEW MEXICO 

BFA Corporation 
312 West Parker Road 
LasCruces 99001 
Tel: (505) 523-0601 
TWX: 910-983-0543 
BFA Corporation 
3705 Westerfield, N.E. 
Albuquerque 87111 
Tel: (505) 292-1212 
TWX: 910-989-1157 



SCANDINAVIA 

Intel Scandinavia A/S' 

Lyngbvvej 32 2nd Floor 

DK-2100 Copenhagen East 

Denmark 

Tel: (01) 18 20 00 

TELEX: 19567 

Intel Sweden AB' 

Box 20092 

S-16120 Bromma 

Sweden 

Tel : (08) 98 S3 90 
TELEX: 12261 



TAIWAN 

Taiwan Automelion Co.' 
6th Floor, lfl-1, Lane 14 
Chi-Lin Road 
Taipei 

Tel: (02) 551728-9 
TELEX: 11942 TAIAUTO 



NEW YORK 

Intel Corp.' 

6901 Jericho Turnpike 

Syosset 11791 

TbI: (516) 364-9860 

TWX: 510-221-2198 

Intel Corp. 

474 Thurston Road 

Rochester 14619 

Tel: (716) 328-7340 

TWX; 510-253-3841 

T-Squared 

4054 Newcourt Avenue 

Syracuse 13206 

Tel: (315) 483-8592 

TWX: 710-541-0554 

T-Squared 

640 Kreag Road 

P.O. Box W 

Pittslord 14534 

Tel: (716) 381-2551 

TELEX: 97-8289 

Intel Corp. 

55 Market Street 

Poughkeepsie 12601 

Tel: (914) 473-2303 

TWX: 510-248-0060 

Measurement Technology, inc. 

295 Northern Boulevard 

Great Neck 11021 

Tel: (518) 482-3500 

NORTH CAROLINA 

Col-lns-Co 
2873 Monlicello Drive 
Winston-Salem 27106 
Tel: (800) 327-6600 

OHIO 

Intel Corp.' 

831 2 North Main Street 

Dayton 45415 

Tel: (513) 890-5350 

TELEX: 288-004 

Intel Corp.* 

26250 Euclid Ave. 

Suite 531 F 

Euclid 44132 

Tel: (216) 289-0101 

Carter, McCormic 5 Peirce, Inc. 

21380 Lorain Road 

Cleveland 44126 

Tel: (218) 333-5650 

Carter, McCormic & Peirce, Inc. 

5423 Wel>ster Street 

Dayton 45414 

Tel: (513) 278-5873 



ENGLAND 

Intel Corporation (U.K.) Ltd.' 

Broaddeld House 

4 Between Towns Road 

Cowley, Oxford 0X4 3NB 

Tel: (0865) 77 14 31 

TELEX; 837203 

Intei Corporation (U.K.) Ltd. 

46-50 Beam Street 

Nantwich, Cheshire CW5 5LJ 

Tel: (0270) 62 85 60 

TELEX: 36620 



TAIWAN (conL) 

As ionics- Taiwan, Inc. 

205 Pa-Teh Road, Section 4 

Taipei 

Tel: 75 55 82 

TELEX: 221 58 Asionics 



OREGON 

ES/Chase Company 

P.O. Box 602 

Beaverton 97005 

Tel: (503) 642-2732 or 226-2521 

PENNSYLVANIA 

Intel Corp.* 

520 Pennsylvania Ave. 

Fort Washington 19034 

Tel; (215) 542-9444 

TWX: 510-661-0709 

Carter, WcCormlc & Pairce, Inc. 

409 Beatty Road 

Monroeville 15146 

Tel: (412) 372-4415 

TEXAS 

Microsystems Marketing Inc. 

13777 N. Central Expressway 

Suite 405 

Dallas 75231 

Tel: (214) 238-7157 

TWX: 910-867-4763 

Microsystems Markeling Inc. 

6610 Harwin Avenue, Suite 125 

Houston 77036 

Tel: (713) 783-2900 

Intel Corp.* 

6350 L.B.J. Freeway 

Suite 178 

Dallas 75240 

Tel: (214) 661-8829 

TWX: 910-860-5487 

UTAH 

BFA Corporation 
395 Lawndale Drive 
Salt Lake City 84115 
Tel: (801)468-8522 
TWX: 910-925-5686 

WASHINGTON 

E.S. /Chase Co. 
P.O. Box 80903 
Seattle 98108 
Tef: (208) 762-4824 
TWX: 910-*44-2298 



CANADA 

Intel Corp. 

70 Chamberlain Ave. 
Ottawa. Ontario KIS 1V9 
Tel: (613) 232-8576 
TELEX; 053-4419 
Multiiek, Inc." 
4 Barren Street 
Ottawa, Ontario K2J 1G2 
Tal:(613) 825-4553 
TELEX: 053-4585 



GERMANY 

Intel SemicondjctorGmbH* 

Seidlstrasse 27 

8000 Muenchen 2 

Tel: (039) 55 81 41 

TELEX: 523 177 

Intel Semiconductor GmbH 

D-6272 Niedernhausen 

Wiesenweg 28 

Tel: (08127) 2314 

TELEX: 04186183 

Intel Semiconductor GmbH 

D-7000 Stuttgart 80 

Ernsthaidenstrasse 17 

Tel: (0711) 7351506 

TELEX: 7255346 



INTERNATIONAL DISTRIBUTORS 



AUSTRALIA 

A. J. Ferguson (Adelaide) PTY, Lid. 

44 Prospecl Rd. 

Prospect 5082 

South Australia 

Tel: 289-1244 

TELEX: 82635 

Warburton O'Donnell Limited 
372 Eastern Valley Way 
Chatswood. N.S.W. 2067 
Tel: 407 3281 

TELEX: WARFRAN AA 21299 
AUSTRIA 

Bacher Elektronische GerateGmbH 
Meidlinger Hauptslrasse 78 
A 1120 Vienna 
Tel: (0222) 83 63 96 
TELEX: (01) 1532 

BELGIUM 

Ineico Belgium S.A, 
Avenue Vel Duchesse, 3 
B-1160 Brussels 
Tel: (02) 860 00 12 
TELEX: 25441 

DENMARK 

Scandinavian Semiconductor 
Supply A/S 
Nannasgade 18 
DK-2200 Copenhagen N 
Tel: (01) 93 50 90 
TELEX: 19037 



FINLAND 

Oy Fintronic AB 
Loennrotlnkatu 3SD 
SF 00180 
Helsinki 18 
Tel; (90) 884 451 
TELEX: 12426 

FRANCE 

Tekelec Airtronic 
Cite des Bruyeres 
Rue Carle Vernet 
92310 Sevres 
Tel: (1) 027 75 35 
TELEX: 250997 

GERMANY 

Alfred Neye Enatachnik GmbH 

Schlllerstrasse 14 

D-2085 Qufckborn-Hamburg 

Tel; (04108) 8121 

TELEX; 02-13590 

Electronic 2000 Vartriebs GmbH 

Ne u marketer St rasse 75 

D-8000 Muenchen 80 

Tel: (089) 434081 

TELEX: 484426 

Jermyn GmbH 

Posilach 1146 

D-6277 Kamberg 
Tel: (06434) 8O05 
TELEX: 484426 



HONG KONG 

ASTEC International 
Keystone House, 2nd Floor 
Hankow Road, Kowloon 
Tel: 3-887760 
TELEX: 74899 ASCOM 

ISRAEL 

Eastronics Ltd.* 
1 1 Rozanis Street 
P.O. Box 39300 
Tel-Aviv 
Tel: 475151 
TELEX: 33638 

ITALY 

Eiedra 3SS.P.A.- 
Viale Elvezia, 18 
20154 Milan. 
Tel: (02) 3493041 
TELEX: 39332 
EledraSSS.P.A.* 
Via Paolo Gaidano, 141 D 
10137 Torino 

TEL: (Oil) 30 97 097 -30 97 114 

Eledra 3SS.P.A.' 

Via Giuseppe Valmarana, 63 

00139 Rome, Italy 

Tal: (06)81 27 290-81 27 324 

TELEX: 63051 

JAPAN 

Pan Electron 
No. 1 Higashlkata-Machi 
MIdori-Ku. Yokohama 226 
Tel: (045) 471-8811 
TELEX: 781-4773 



JAPAN (cont.) 

Ryoyo Electric Corp. 
Konwa BIdg. 

1-12-22, Tsukiji, 1-Chome 
Chuo-Ku, Tokyo 104 
Tel: (03) 543-7711 

NETHERLANDS 

Ineico Nederland 
AFD Elektronic 
Joan Muyskenweg 22 
NL-10Q8 Amsterdam 
Tel: (020) 934824 
TELEX: 14822 

NORWAY 

Nordlsk Elektronik (Norge) A/S 
Mustads Vei 1 
N-Oslo 2 

Tel: (02) 55 38 93 
TELEX: 16963 

PORTUGAL 

Ditram 

Componentes E Electronica LDA 
Av. Miguel Bombarda, 133 
Lisboa 1 
Tel: 119 45 313 

SOUTH AFRICA 

Electronic Building Elements 

P.O. Box 4809 

Pretoria 

Tel: 78 92 21 

TELEX: 30181 

SPAIN 

Interface 

Ronda San Pedro 22 
Barcelona 10 

Tel: 301 78 51 



SWEDEN 

Nordlsk Electronik AB 
Pack 

S-10380 Stockholm 7 
Tel: (08) 248340 
TELEX: 10547 

SWITZERLAND 

Industrade AG 
Gemsenstrasse 2 
Postcheck flO- 21190 
CH-8021 Zurich 
Te1:(01)80 22 30 
TELEX: 56788 

UNITED KINGOOM 

Rapid Recall, Ltd. 

11-15 Belterlon Street 

Drury Lane 

London WC2H 9BS 

Tel: (01) 379-6741 

TELEX: 28752 

G.E.C. Semiconductors Ltd. 

East Lane 

Wembley HA9 }pp 

Middlesex 

Tel: (01) 904-9303 

TELEX: 923429 

Jermy-n industries 

Vestry Estate 

Sevenoaks. Kent 

Tel: (0732) 50144 

TELEX; 95142 



* Field Appltcatlon Location 
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